>[success] # 插入排序
[不错的文章先读一下](https://juejin.im/post/6844904167778041869#heading-0)
~~~
1.引用书里的话来说,插入排序每次排一个数组项,以此方式构建最后的排序数组。假定第一项已经排序了。
接着, 它和第二项进行比较——第二项是应该待在原位还是插到第一项之前呢?这样,头两项就已正确 排序,
接着和第三项比较(它是该插入到第一、第二还是第三的位置呢),以此类推。
2.通俗的理解'插入排序'和'选择排序' 在整体思路方面差不多,首先'插入排序'也是将整个排序分成两个区间,
分别是'排序区间'和'未排序区间',每次会从'未排序区间'中取值去以排序区间中比较,比较后将这个值插入到
'以排序区间'
3.'插入排序'和'选择排序' 做个比较理解,'插入'是从'未排序区间'取值在'以排序区间去比较','选择'是从'未排序区间'
依次找到最小值放到'以排序区间'
4.如图红色区域就是'已排序区间',黄色就是'未排序'区间,依次从黄色区域取值去红色区域比较,并且将值插入到
合适的红色区域
~~~
![](https://box.kancloud.cn/be81c151f38d8923fe1ede31ac530ac4_811x505.gif)
![](https://img.kancloud.cn/97/42/97425c50afdde006032fb7eaf691df49_535x326.png)
>[info] ## 代码实现
* 通用方法
~~~
// 生成随机数数组
function randomArray(max, min, len) {
let randomNum = 0
const array = []
for (let i = 0; i < len; i++) {
randomNum = Math.floor((Math.random() * (max - min + 1)) + min)
array.push(randomNum)
}
return array
}
const array = randomArray(1, 10, 5)
const Compare = {
LESS_THAN: -1,
BIGGER_THAN: 1,
EQUALS: 0
};
function defaultCompare(a, b) {
if (a === b) {
return Compare.EQUALS;
}
return a < b ? Compare.LESS_THAN : Compare.BIGGER_THAN;
}
~~~
>[danger] ##### 代码效果
~~~
1.这里默认将第一个元素作为'已排序'区间中的内容,这样方便后续逻辑
2.通过过动态图来理解下面插入算法中的while逻辑,首先是吧整个数组分成两个区域
'已排序区域' 一个是 '为排序区域',第一层for是从为排序区域取出一个,'已排序区域'就是
从当前这个值往后都是以排序区域,因此while 的判断循环j 是从取点位置开始的,注意
动图插入的那个动作,如果你比我小我就把你往后移动,如果你比我大我就到大了位置,
整个while 就结束了,这个值就到了j的位置
~~~
~~~
// 插入排序
function insertionSort(array, compareFn = defaultCompare) {
const {
length
} = array;
let temp;
for (let i = 1; i < length; i++) {
let j = i;
temp = array[i];
while (j > 0 && compareFn(array[j - 1], temp) ===
Compare.BIGGER_THAN) {
array[j] = array[j - 1];
j--;
}
array[j] = temp;
}
return array;
};
insertionSort(array)
console.log(array)
~~~
- 接触数据结构和算法
- 数据结构与算法 -- 大O复杂度表示法
- 数据结构与算法 -- 时间复杂度分析
- 最好、最坏、平均、均摊时间复杂度
- 基础数据结构和算法
- 线性表和非线性表
- 结构 -- 数组
- JS -- 数组
- 结构 -- 栈
- JS -- 栈
- JS -- 栈有效圆括号
- JS -- 汉诺塔
- 结构 -- 队列
- JS -- 队列
- JS -- 双端队列
- JS -- 循环队列
- 结构 -- 链表
- JS -- 链表
- JS -- 双向链表
- JS -- 循环链表
- JS -- 有序链表
- 结构 -- JS 字典
- 结构 -- 散列表
- 结构 -- js 散列表
- 结构 -- js分离链表
- 结构 -- js开放寻址法
- 结构 -- 递归
- 结构 -- js递归经典问题
- 结构 -- 树
- 结构 -- js 二搜索树
- 结构 -- 红黑树
- 结构 -- 堆
- 结构 -- js 堆
- 结构 -- js 堆排序
- 结构 -- 排序
- js -- 冒泡排序
- js -- 选择排序
- js -- 插入排序
- js -- 归并排序
- js -- 快速排序
- js -- 计数排序
- js -- 桶排序
- js -- 基数排序
- 结构 -- 算法
- 搜索算法
- 二分搜索
- 内插搜索
- 随机算法
- 简单
- 第一题 两数之和
- 第七题 反转整数
- 第九题 回文数
- 第十三题 罗马数字转整数
- 常见一些需求
- 把原始 list 转换成树形结构