基本排序算法

一.插入排序
算法描述:

  1. 从第一个元素开始,该元素可以认为已经被排序
  2. 取出下一个元素,在已经排序的元素序列中从后向前扫描
  3. 如果该元素(已排序)大于新元素,将该元素移到下一位置
  4. 重复步骤 3,直到找到已排序的元素小于或者等于新元素的位置
  5. 将新元素插入到该位置后
  6. 重复步骤 2~5
function insertSort(arr){
      var temp;
       for(var i = 0; i< arr.length; i++){
            temp = arr[i];
             for(var j = i; j> 0; j--){
                  if(temp < arr[j-1]){
                        arr[j] = arr[]j-1]
                  }else{
                        arr[j] = temp;
                        break;
                  }
              }
      }
      return arr;
}

二.选择排序
算法描述:直接从待排序数组中选择一个最小(或最大)数字,放入新数组中。
编程思路:先假设第一个元素为最小的,然后通过循环找出最小元素,然后同第一个元素交换,接着假设第二个元素,重复上述操作即可。

function inserSort(arr){
      var minIndex,minValue;
      for(var i = 0; i<arr.length - 1; i++){
            minIndex = i;
            minValue = arr[minIndex];
            for(var j = i+1; j<arr.length; j++){
                   if(arr[j] < minValue){
                           minIndex = j;
                           minValue = arr[minIndex];
                    }
            }
            var temp = arr[i];
            arr[i] = minValue;
            arr[minIndex] = temp;
      }
      return arr;
}

三.冒泡排序
算法描述:

  1. 比较相邻的元素。如果第一个比第二个大,就交换他们两个。
  2. 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。
  3. 针对所有的元素重复以上的步骤,除了最后一个。
  4. 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。
function insertSort(arr){
    for(var i = 0; i<arr.length; i++){
        for(var j = i; j<arr.length; j++){
            if(arr[j] < arr[j+1]){
                var temp = arr[j];
                arr[j] = arr[j+1];
                arr[j + 1] = temp;  
            }
        }
    }
    return arr;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序,希尔排序,归并排序,快速排序,堆排序,计数排序...
    EINDEX阅读 1,267评论 5 14
  • 文章大纲:1.总体排序算法对比图2.9种排序算法介绍 冒泡排序 算法描述 冒泡排序是一个平均时间复杂度为O(n^2...
    柠檬乌冬面阅读 4,120评论 0 73
  • 排序算法是最基本最常用的算法,不同的排序算法在不同的场景或应用中会有不同的表现,我们需要对各种排序算法熟练才能将它...
    若丶天下阅读 448评论 0 1
  • 1. 简介 排序与我们日常生活中息息相关,比如,我们要从电话簿中找到某个联系人首先会按照姓氏排序、买火车票会按照出...
    DraculaWong阅读 362评论 0 0
  • 26岁,你看着身边的人都结了婚 婚礼的份子钱逐年递增 春节回家,父母从带你串亲戚 变成了带你去见相亲对象 见了十几...
    一点都不酷_67a1阅读 571评论 0 0