数组和算法-数组排序-插入排序

插入排序

今天来聊聊插入排序,我们还是先说它的思想

基本思想:我们可以把数组的每一个值,想象成扑克牌,这样更实物化,更形象化一点。我们从数组中拿出第一张牌,放在左手,以后拿到每一张牌的时候和左手中的牌进行比较(一般来说,我们是从后往前比),如果你拿到的当前的牌比倒数第一张小,再继续往左比。。。,一直到遇到当前的牌比某张牌打了,则把这张牌插入到某张牌的后边(也就是说某张牌下一张牌的前面)

说完思想直接上程序吧,因为前面说了两个排序方法,第三个大家应该能看懂

var ary = [6,3,5,7,2,4];
    function insertSort(ary) {
        var newAry = [];//存储的是左手中的牌
        newAry.push(ary[0]);//先抓第一张牌
        // 依次把桌面的牌抓到按照基本思想进行比较
        for(var i=1;i<ary.length;i++){
            var cur = ary[i];//抓到的当前的牌,然后从后往前和左手中的牌进行比较
            for(var j=newAry.length-1;j>=0;){//要和左手的牌,进行一个一个比较,因此要循环左手的牌(从后往前循环)
                if(cur<newAry[j]){ //当前新牌比左手中的这张牌小,继续和newAry[j]前面的一张牌进行比较
                    j--;
                    if(j==-1){// 说明当前的牌比左手中的牌都小,我们就把这张牌放在左手的开头位置即可
                        newAry.unshift(cur);
                    }
                }else {//当前新牌比左手中的这张牌大,则放在这张牌的后面,也相当于newAry[j+1]的前面
                    newAry.splice(j+1,0,cur);
                    break;// 跳出此for循环的程序段;不影响上一个for程序段
                }
            }
        }
        return newAry;
    }
    var res = insertSort(ary);
    console.log(res);

结果为 [2, 3, 4, 5, 6, 7]

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一. 写在前面 要学习算法,“排序”是一个回避不了的重要话题,在分析完并查集算法和常用数据结构之后,今天我们终于可...
    Leesper阅读 2,562评论 0 40
  • 数据结构与算法--排序之冒泡、选择、插入、希尔 我们关注的主要对象是重新排列数组元素的算法,每个元素都有一个主键,...
    sunhaiyu阅读 1,175评论 2 12
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,237评论 0 52
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,753评论 0 15
  • 7月了。是的,真的要毕业了。 有的事,一直在期盼它来临。而当它真正到来,又会衍生许多复杂感受,夹杂着所处境地,糅合...
    微语Shirley阅读 442评论 0 1