美文网首页
数组和算法-数组排序-插入排序

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

作者: 落雨飞尘 | 来源:发表于2017-06-30 09:48 被阅读0次

插入排序

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

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

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

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]

相关文章

  • 基础算法-选择插入排序

    今天学习两个简单的数组排序算法,选择排序和插入排序。 题目介绍 给定一个数组,将数组按从小到大顺序排序。题目理解起...

  • 再写排序

    对于一个int数组,请编写一个插入排序算法,对数组元素排序。给定一个int数组A及数组的大小n,请返回排序后的数组...

  • 看动画学算法之:排序-插入排序

    简介 插入排序就是将要排序的元素插入到已经排序的数组中,从而形成一个新的排好序的数组。 这个算法就叫做插入排序。 ...

  • JavaScript的排序算法——插入排序

    插入排序(Insertion Sort) 插入排序是一种简单的排序算法,这种算法可以一次构建最终排序的数组(或数列...

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

    插入排序 今天来聊聊插入排序,我们还是先说它的思想 基本思想:我们可以把数组的每一个值,想象成扑克牌,这样更实物化...

  • 排序算法

    常见的排序算法 常见的排序算法有:插入、希尔、选择、冒泡、归并、快速、堆排序。。。 插入排序 算法步骤一、从数组的...

  • 插入排序和冒泡排序

    插入排序算法: 在一个有序的数组中插入一个数据,要求该数据插入后数组仍然有序。在插入排序中有序的数组就是指已经排好...

  • 面试基础算法复习

    排序算法 选择排序、冒泡排序、插入排序三种排序算法可以总结为如下:都将数组分为已排序部分和未排序部分。选择排序将已...

  • 2020前端面试(数据结构)

    常见排序算法 冒泡排序 快速排序 选择排序 插入排序 数组扁平化 递归 reduce toString 树的遍历 ...

  • 排序

    本文讲数组的排序,排序复杂度分为O(n²)和O(nlogn)。其中:O(n²)的算法有:插入排序[https://...

网友评论

      本文标题:数组和算法-数组排序-插入排序

      本文链接:https://www.haomeiwen.com/subject/drsbcxtx.html