排序:希尔排序
来源:互联网 发布:物流企业利润率的算法 编辑:程序博客网 时间:2024/06/03 21:22
介绍了2种希尔排序的实现方式。
#include <stdio.h>// 交换函数void swap (int a[], int i, int j){int tmp = a[i];a[i] = a[j];a[j] = tmp;}// 打印数组void printA (int *a, int len){int i;for (i = 0; i < len; i++){printf ("%4d", a[i]);}printf ("\n");}// 希尔排序int main1(){int a[10] = {9,6,8,0,3,5,2,4,7,1};int len = sizeof(a) / sizeof(a[0]);int i,j,get;int d = len; // d代表每一次的步长do{d = d / 3 + 1;for (i = d; i < len; i++){get = a[i];j = i - d;while (j >= 0 && a[j] > get){a[j+d] = a[j];j -= d;}a[j+d] = get;}}while (d > 1);printA (a, len);return 0;}int main(){int a[10] = {9,6,8,0,3,5,2,4,7,1};int len = sizeof(a) / sizeof(a[0]);int i,j,get;int d = 0; // d代表每一次的步长while (d < len){d = d * 3 + 1; // 0 1 4 13}while (d >= 1){for (i = d; i < len; i++){get = a[i];j = i - d;while (j >= 0 && a[j] > get){a[j+d] = a[j];j -= d;}a[j+d] = get;}d = (d-1) / 3; // 4 1 0}printA (a, len);return 0;}
阅读全文
0 0
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- 希尔排序
- JAVA入门
- GCD和LCM的一些性质
- 对Systemc的一点个人看法
- DropWizard--轻量级REST开发框架初次搭建
- HDU4734 F(x)(数位DP)
- 排序:希尔排序
- 复合文档格式(二)
- [填坑]关于矩阵乘和快速幂(初学必入)
- 关于vue引入问题说明
- 事务管理之JDBC事务
- effective c++:资源管理相关
- GIT——基本配置
- Java 9 揭秘(16. 虚拟机栈遍历)
- 宏函数和函数的区别以及优缺点