一、
函数:void Inc_Sort(int* head,int low,int high,int Step_L,int Bool)
参数解释
head:数组指针
[low, high]:需排序的数组范围
Step_L:需排序步长
Bool:等于1表示从小到大排序,不等于1从大到小排序
说明
反向扫描数组中i到low范围
遇到更大的值则交换,遇到更小的值则进行下一次循环,通过交换,使得数组low到i范围始终有序
Step_L=1时
第一步对下标low+{0,1,2,3,4,5…}插入排序
Step_L=2时
第一步对下标low+{0,2,4,6,8,10…}插入排序
Step_L=3时
第一步对下标low+{0,3,6,9,12,15…}插入排序
以此类推
此方法每遇到更大的值需要交换一次
最多的交换次数为第一层循环次数*第二层循环次数(第二层循环每一次循环都需要交换)
#include#include //插入排序,head:数组头,[low,high]:排序范围,Step_L:需排序的元素之间的间隔,Bool:正逆序 void Inc_Sort(int* head,int low,int high,int Step_L,int Bool){ int Shigh=low+(((high-low+1)/Step_L)-1+(((high-low+1)%Step_L)!=0))*Step_L;//Step_L属于{low,low+Step_L,low+2*Step_L,...,Shigh} int temp;//保存插入值 int temp1;//交换 for(int i=low+Step_L;i<=Shigh;i+=Step_L){ temp=head[i]; for(int j=i-Step_L;j>=low;j-=Step_L){ if((temp



