温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

一种简单的直接插入排序精解

发布时间:2020-06-25 15:44:42 来源:网络 阅读:513 作者:小沄 栏目:开发技术

    直接插入排序,就像是桌子上一叠正面向下的扑克从小到大地依次拿到自己的手上。

1,显然拿到的第一张扑克(假如是3)是不用比较的,而且可以认为,它是有序的。

2,拿到第二张牌(假如是2)的时候,我们只要和第一张比较,放到合适的位置(现在是2,3),保持有序。

3,接着拿到第三张牌,我们只要和原来有序的序列(2,3)比较组成一个元素加一个的新有序序列即可。

(我们只要从右到左用在原序列一个个比较即可,如是5,只比较一次就可以决定放在3前,如果是1,那就比较两次)

详解如下图:


一种简单的直接插入排序精解


要点:

1,大循环从第二个元素开始,倒着比较

2,小循环的条件有两种情况

3i在一趟比较的最后要加1,向后一格置入新元素

特征:

1,插入排序是原址排序,最多用了一个辅助空间来放临时元素

2,新元素之前的部分是本问题的子问题的求解结果

3,完全逆序的比较性能最差(内层循环的次数最多)


for(j=1 ;  j< arr.length ; j++)

{

        key = arr[ j] ;//取出当前要插入比较的新元素

        i = j-1;//小循环指示器

        while( i> -1 && arr[i]>key) {//小循环负责在已经有序的部分中找个合适的位置

                arr[i+1] = arr [i] ;//有序部分比新来元素较大者后移

                --i;//继续向前寻找位置

        }

        i=i+1;

        arr[i] =  key;//无论是否进入了小循环,把key放在i+1的位置总是对的

  //没有进入小循环的ij是同一个位置

}



本文已完结;

by mengshengneng@163.com

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI