让前端飞

js算法——插入排序

2018-10-26  本文已影响3人  jia林

思路

1、对于插入排序来说,第1个元素 (索引为0) 不用考虑,在开始计算时,第1个元素排在第一位,本身就已经有序了,不需要把他放在前面的任何位置,所以是从第二个元素(索引为1)开始计算,进行第一层循环
2、第二层循环是从第i个元素的位置开始,向前计算,每一次是把当前元素和前一位元素作比较,看看是否能放在前一个元素的位置,最后发生的位置是在第一层循环i的位置,i=1,所以j>0
3、j初始化为i,j这个索引指向的是当前要考察的元素位置
4、判断当前位置是不是比前一位要小,如果还要小的话就调换一下
5、之后运行j--,向前依次查看

 function insertSort(arr){
        var len = arr.length;
        for(var i =1;i<len;i++){
            var result = null;
            for(var j = i;j>0 && arr[j] < arr[j-1];j--){
                // 调换两者的位置
                    result = arr[j];
                    arr[j] = arr[j-1];
                    arr[j-1] = result
            }

        }
        return arr
    }
    var arr = [3,6,1,0,67];
    console.log(insertSort(arr))
上一篇 下一篇

猜你喜欢

热点阅读