插入排序C语言插入排序法

插入排序  时间:2021-01-08  阅读:()

什么是插入排序?有什么特点

本人不擅长文字表达给你写个例子吧 10 6 12 7 9 2 14 31 插入排序从小到大 第一趟 6 10 12 7 9 2 14 31 第二趟 6 10 12 7 9 2 14 31 第三趟 6 7 10 12 9 2 14 31 第四趟 6 7 9 10 12 2 14 31 第五趟 2 6 7 9 10 12 14 31 第六趟 2 6 7 9 10 12 14 31 第七趟 2 6 7 9 10 12 14 31

直接插入排序 和插入排序有什么区别??

直接插入排序 直接插入排序(straight insertion sort)的作法是: 每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。

第一趟比较前两个数,然后把第二个数按大小插入到有序表中; 第二趟把第三个数据与前两个数从前向后扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。

直接插入排序属于稳定的排序,最坏时间复杂性为O(n^2),空间复杂度为O(1)。

直接插入排序是由两层嵌套循环组成的。

外层循环标识并决定待比较的数值。

内层循环为待比较数值确定其最终位置。

直接插入排序是将待比较的数值与它的前一个数值进行比较,所以外层循环是从第二个数值开始的。

当前一数值比待比较数值大的情况下继续循环比较,直到找到比待比较数值小的并将待比较数值置入其后一位置,结束该次循环。

值得注意的是,我们必需用一个存储空间来保存当前待比较的数值,因为当一趟比较完成时,我们要将待比较数值置入比它小的数值的后一位 插入排序类似玩牌时整理手中纸牌的过程。

插入排序的基本方法是:每步将一个待排序的记录按其关键字的大小插到前面已经排序的序列中的适当位置,直到全部记录插入完毕为止。

插入排序 有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。

是稳定的排序方法。

插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外,而第二部分就只包含这一个元素。

在第一部分排序后,再把这个最后元素插入到此刻已是有序的第一部分里的位置。

插入法排序!!

就像打牌的时候把扑克牌排序一样 把a[i]插入到前i-1个已经排好序的序列当中 生成长度为i的序列 依次向后处理。

#include<iostream> using namespace std; int a[100],n; int main() { cin>>n; //读入 for (int i=1;i<=n;i++) cin>>a[i]; for (int i=2;i<=n;i++)//排序 从2开始(明白?) { int p=i; while (p>1&&a[p]<a[p-1]) {swap(a[p],a[p-1]);p--;}//向前找到合适的位置 } for (int i=1;i<n;i++) cout<<a[i]<<" ";//输出 cout<<a[n]<<endl; return 0; }

插入排序,快速排序哪个更快?

当数据量小于1000时相差很小。

当数据量大于10000时,数据量越大,差别越明显。

是快速排序速度快。

C语言插入排序法

for(i=1;i<4;i++) //外层 { t=a[i]; for( j=i-1 ; j>=0 && t>a[j] ; j-- ) //内层 a[j+1]=a[j]; a[j+1]=t; } 你要理解插入排序的原理,外层for从第二个数开始遍历(i从1开始),用t(即对应的a[i])和其前面的所有值进行比较,如果t大,则该数后移一位,直到t小或者j小于0的时候退出内层for循环,这时候出现的格局就是所有在i位置之前比a[i]小的值全部后移了一位,退出循环时就会空出一个位置来。

举个例子:输入:1 3 2 4 第一次循环时,t=a[1]=3,t>a[0],所以a[0]后移一位(即:a[j+1]=a[j] -> a[1]=a[0]),之后出现结果:1124,这时候实际上0位置是给此时的t预留的位置,内层for执行完毕后,执行:a[j+1]=t 正好弥补这个空缺。

结果:3124 第二次循环时,j=1,t=a[2]=2,t>a[1],所以a[1]后移一位:a[2]=a[1],之后结果:3114,在比较t和a[0],t小,跳出内层for,跳出时j为0,执行:a[1]=t=2,结果:3214 下面就不讲了,从上面可以看出,你说的那一句,至关重要,外层for每循环一次就插入一位数据,而a[j+1]=t,就是完成插入的最后一步。



妮妮云(119元/季)日本CN2 2核2G 30M 119元/季

妮妮云的知名度应该也不用多介绍了,妮妮云旗下的云产品提供商,相比起他家其他的产品,云产品还是非常良心的,经常出了一些优惠活动,前段时间的八折活动推出了很多优质产品,近期商家秒杀活动又上线了,秒杀产品比较全面,除了ECS和轻量云,还有一些免费空间、增值代购、云数据库等,如果你是刚入行安稳做站的朋友,可以先入手一个119/元季付的ECS来起步,非常稳定。官网地址:www.niniyun.com活动专区...

PacificRack:洛杉矶KVM月付1.5美元起,1G内存套餐年付12美元起

PacificRack在本月发布了几款特价产品,其中最低款支持月付仅1.5美元,基于KVM架构,洛杉矶机房,PR-M系列。PacificRack简称PR,QN机房旗下站点,主要提供低价VPS主机产品,基于KVM架构,数据中心为自营洛杉矶机房,现在只有PR-M一个系列,分为了2个类别:常规(Elastic Compute Service)和多IP产品(Multi IP Server)。下面列出几款秒...

Central美国65折优惠,美国达拉斯机房VPS季付赠送双倍内存

Central美国独立日活动正在进行中,旗下美国达拉斯机房VPS 65折优惠,季付赠送双倍内存(需要发工单),Central租用的Hivelocity的机房,只支持信用卡和加密货币付款,不支持paypal,需要美国独服的可以谨慎入手试试。Central怎么样?Central便宜服务器,Central自称成立于2019年,主营美国达拉斯机房Linux vps、Windows vps、专用服务器和托管...

插入排序为你推荐
软银支付软银支付可靠吗?骁龙750g和765g哪个好骁龙765G,这里的g是什么意思?骁龙750g和765g哪个好765g和855+比有什么优缺点?麒麟820和980哪个好麒麟980和骁龙855那个好一点?等额本息等额本金哪个好等额本息与等额本金哪个划算?英语词典哪个好英语词典哪种更好啊?网校哪个好市面上的网校,谁最好?红茶和绿茶哪个好红茶和绿茶哪个好?播放器哪个好什么手机视频播放器比较好用?电动牙刷哪个好电动牙刷哪个牌子比较好,不要那么贵的
美国网站空间 中国十大域名注册商 淘宝二级域名 申请免费域名 花生壳免费域名 漂亮qq空间 圣迭戈 免费名片模板 2017年万圣节 个人免费空间 圣诞促销 vip购优汇 韩国名字大全 秒杀汇 adroit tna官网 umax120 中国网通测速 web服务器安全 免费网页空间 更多