栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

3-间隔插入排序C实现(希尔排序铺垫)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

3-间隔插入排序C实现(希尔排序铺垫)

一、
函数: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
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/304362.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号