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;

}

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

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

相关推荐
liuqun031923 分钟前
开心灿烂go开发面试题
算法·leetcode·golang
liulilittle35 分钟前
通过高级处理器硬件指令集AES-NI实现AES-256-CFB算法并通过OPENSSL加密验证算法正确性。
linux·服务器·c++·算法·安全·加密·openssl
小皮侠37 分钟前
【算法篇】逐步理解动态规划模型6(回文串问题)
java·开发语言·算法·动态规划
移动开发者1号37 分钟前
Android 多 BaseUrl 动态切换策略(结合 ServiceManager 实现)
android·kotlin
IT猿手37 分钟前
动态多目标进化算法:基于迁移学习的动态多目标粒子群优化算法(TrMOPSO)求解IEEE CEC 2015,提供完整MATLAB代码
算法·matlab·迁移学习·动态多目标进化优化·动态多目标算法
移动开发者1号39 分钟前
Kotlin实现文件上传进度监听:RequestBody封装详解
android·kotlin
勤奋的小王同学~39 分钟前
(javaSE)抽象类和接口:抽象类概念语法和特性, 抽象类的作用;接口的概念 接口特性 实现多个接口 接口间的继承 Object类
java·开发语言
এ᭄画画的北北40 分钟前
力扣-279.完全平方数
数据结构·算法·leetcode
实习生小黄1 小时前
双三次贝塞尔曲面-canvas 实现4x4网格图片变化功能
前端·算法
jz_ddk1 小时前
[学习] FIR多项滤波器的数学原理详解:从多相分解到高效实现(完整仿真代码)
学习·算法·matlab