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 = arr[i];

int j;

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

for (j = i; j >= gap && arr[j - gap] > temp; j -= gap) {

arr[j] = arr[j - gap];

}

arr[j] = temp;

}

}

}

// 打印数组

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

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

printf("%d ", arr[i]);

}

printf("\n");

}

// 主函数

int main() {

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

int n = sizeof(arr) / sizeof(arr[0]);

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

printArray(arr, n);

shellSort(arr, n);

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

printArray(arr, n);

return 0;

}

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

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

相关推荐
嵌入式修炼师7 分钟前
深入理解 QVectorQString:Qt 中动态数组的强大力量
开发语言·qt
指掀涛澜天下惊8 分钟前
DirectX12(D3D12)基础教程三 线性代数与3D世界空间
线性代数·算法·机器学习·3d
浪子西科25 分钟前
【数据结构】(Python)第六章:图
开发语言·数据结构·python
程序趣谈34 分钟前
算法随笔_57 : 游戏中弱角色的数量
数据结构·python·算法
kongba00741 分钟前
EIDE搭配cursor编译GD32的项目 需要的一些c_cpp_properties设置 json文件
c语言·开发语言·json
抹除不掉的轻狂丶43 分钟前
JVM生产环境问题定位与解决实战(三):揭秘Java飞行记录器(JFR)的强大功能
java·开发语言·jvm
Hello.Reader1 小时前
Rust 中的引用循环与内存泄漏
开发语言·windows·rust
xianwu5431 小时前
反向代理模块kfj
开发语言·网络·数据库·c++·mysql
滨HI01 小时前
P8772 [蓝桥杯 2022 省 A] 求和--简单题的陷阱——(不开long long见祖宗!!!
数据结构·c++·算法·职场和发展·蓝桥杯
EPSDA1 小时前
网络基础知识
linux·运维·服务器·开发语言·c++