C语言学习,希尔排序

C语言,希尔排序是插入排序的一种,也称为递减增量排序。通过比较距离较远的元素,然后逐渐缩小间隔,直到整个数组变成有序的。这种排序方法减少了插入排序,大数据集的移动次数,提高了效率。

示例:

// 交换元素

void swap(int *a, int *b) {

int temp = *a;

*a = *b;

*b = temp;

}

// 希尔排序

void shellSort(int arr\[\], int n) {

// 初始间隔为数组长度的一半,逐渐减小到1

for (int gap = n / 2; gap > 0; gap /= 2) {

// 对每个间隔进行插入排序

for (int i = gap; i < n; i++) {

int temp = arri;

int j;

// 对间隔为gap的子数组进行插入排序

for (j = i; j >= gap && arrj - gap > temp; j -= gap) {

arrj = arrj - gap;

}

arrj = temp;

}

}

}

// 打印数组

void printArray(int arr\[\], int size) {

for (int i = 0; i < size; i++) {

printf("%d ", arri);

}

printf("\n");

}

// 主函数

int main() {

int arr\[\] = {12, 34, 54, 2, 3};

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

printf("排序前的数组: \n");

printArray(arr, n);

shellSort(arr, n);

printf("排序后的数组: \n");

printArray(arr, n);

return 0;

}

希尔排序性能依赖于间隔序列选择,示例使用了简单的间隔减半策略,其它更复杂的间隔序列可能会提高性能。

希尔排序时间复杂度通常优于简单的插入排序,但最坏情况下的时间复杂度仍然较高。

相关推荐
z落落29 分钟前
C# 泛型方法(原理、类型推断、多泛型参数)+泛型效率(普通类型 VS Object装箱 VS 泛型)
开发语言·c#
L_090731 分钟前
【C++】异常
开发语言·c++
Frostnova丶31 分钟前
【算法笔记】数学知识
笔记·算法
xqqxqxxq1 小时前
哈希表(HashMap)技术学习笔记
笔记·学习·散列表
生而为虫1 小时前
[学习记录] 幼儿学习拼音html游戏
学习·游戏
吴可可1231 小时前
AutoCAD 2016与2014二次开发关键差异
算法
AOwhisky1 小时前
MySQL 学习笔记(第四期):SQL 语言之多表查询
linux·运维·网络·数据库·笔记·学习·mysql
世辰辰辰1 小时前
批量修改图片/文本名子
开发语言·python·批量修改文件名
xian_wwq2 小时前
【学习笔记】「大模型安全:攻击面演化史」第 07 篇-安全左移
人工智能·笔记·学习
秋雨梧桐叶落莳2 小时前
iOS——NSUserDefaults学习
学习·macos·ios·objective-c·cocoa