2026.4.29数据结构 直接插入排序&&希尔排序

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <assert.h>

#include <memory.h>

/*

八大排序

难易程度:

4个简单:直接插入排序

4个难:希尔排序

(代码实现话,如果是简单排序,则代码就是双重for循环,里面套一个if)(除了基数)

稳定性:

4个稳定:直接插入排序

4个不稳定:希尔排序

*/

//时间复杂度O(n^2) 空间复杂度O(1) 稳定性:稳定

void Insert_Sort(int arr\[\], int len)

{

for (int i = 1; i < len; i++)//控制的是趟数

{

int tmp = arri;

int j = i - 1;

for (; j >= 0; j--)//控制的是对已排序好的序列的从右至左的访问

{

if (arrj > tmp)//如果比我取出来的值tmp,向后挪动

{

arrj+1 = arrj;

}

else

{

break;//情况1:遇到了不大于我的值,停下来,把值放回去

}

}

//情况2:越界了,停下来,把值放回去

arrj+1 = tmp;

}

}

void Show(int arr\[\], int len)

{

for (int i = 0; i < len; i++)

printf("%d ", arri);

printf("\n");

}

//这个函数代表希尔排序中的单趟处理

void Shell(int arr\[\], int len, int gap_val)

{

//此时增量为5

//需要此时将每一个组执行直接插入排序

for (int i = gap_val; i < len; i++)//此时i控制的需要往前插入的待排序值

{

int tmp = arri;

int j = i - gap_val;

for (; j >= 0; j-=gap_val)//控制的是对已排序好的序列的从右至左的访问

{

if (arrj > tmp)//如果比我取出来的值tmp,向后挪动

{

arrj + gap_val = arrj;

}

else

{

break;//情况1:遇到了不大于我的值,停下来,把值放回去

}

}

//情况2:越界了,停下来,把值放回去

arrj + gap_val = tmp;

}

}

//希尔排序时间复杂度取决于缩小增量的赋值 O(n^1.3 ~ n^1.7) 或者O(n^1.5) 空间复杂度O(1) 稳定性:不稳定

void Shell_Sort(int arr\[\], int len)

{

int Gap\[\] = { 5,3,1 };

int len_Gap = sizeof(Gap) / sizeof(Gap0);

for (int i = 0; i < len_Gap; i++)//趟数

{

Shell(arr, len, Gapi);

}

}

int main()

{

int arr\[\] = { 109,75,20,91,4,75,90,170,15,92,7,5,40,91,7906,15,7,209,56,71,90,54 };

int len = sizeof(arr) / sizeof(arr0);

printf("排序之前:\n");

Show(arr, len);

//Insert_Sort(arr, len);

Shell_Sort(arr, len);

printf("排序之后:\n");

Show(arr, len);

return 0;

}

相关推荐
小白兔奶糖ovo23 分钟前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll26 分钟前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程32 分钟前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程
-To be number.wan33 分钟前
算法日记 | 暴力枚举
学习·算法
s_w.h1 小时前
【 linux 】动静态库的制作
linux·运维·服务器·算法·bash
过期动态1 小时前
【LeetCode 热题 100】接雨水
java·数据结构·算法·leetcode·职场和发展
春日见1 小时前
5分钟入门强化学习之动态规划算法与实现
大数据·人工智能·python·算法·机器学习·计算机视觉
scx_link2 小时前
线性回归的总结:
算法·机器学习·线性回归
郝亚军2 小时前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
青山师2 小时前
动态规划算法深度解析:从状态转移方程到工业级优化
数据结构·算法·面试·动态规划·代理模式·java面试