2018-08-14 插入排序理解

2018-08-14  本文已影响0人  掉了眼的猫

插入排序,

arr = [5, 2, 4, 6, 1, 3]

初始化状态,默认 第一个数是排序好的,也就是说,排序从1开始

for (let i = 1; i < arr.leng; i++)

首先取出一张牌,

var tmp = arr[i]

跟之前的从后向前排序。

var j = i - 1

var arr = [5, 2, 4, 6, 1, 3]

for (let i =1; i < arr.length; i++) {

var tmp = arr[i]

var j = i -1

  while (j >=0 && arr[j] > tmp) {

arr[j +1] = arr[j]

j--;

  }

arr[j +1] = tmp //循环内 j -- 了

}

理解完毕

伪代码:

for i =2 to arr.length

key = arr[i]

j = i - 1

while j >0 and arr[j] > key

arr[j + 1] =arr [j]

j --

arr[j + 1] = key

上一篇 下一篇

猜你喜欢

热点阅读