数据结构13-排序方法之希尔排序的实例
来源:互联网 发布:centos 7 虚拟机上网 编辑:程序博客网 时间:2024/05/08 19:50
程序实现用希尔排序方法对数组序列从大到小的排列,并输出排序后的数列元素,代码如下所示:
#include"stdio.h"void shellsort(int k[],int n){int i,j,flag,gap=n;int tmp;while(gap>1){gap=gap/2; /*增量缩小,每次减半*/do{ /*子序列应用冒泡排序*/flag=0;for(i=1;i<=n-gap;i++){j=i+gap;if(k[i]<k[j]){tmp=k[i];k[i]=k[j];k[j]=tmp;flag=1;}}}while(flag != 0);}}main(){int i,a[11]={-111,2,5,6,3,7,8,0,9,12,1}; /*初始化序列,a[0]可任意置数*/printf("The orginal data array is\n"); /*显示原序列之中的元素*/for(i=1;i<=10;i++)printf("%d ",a[i]);shellsort(a,10); /*执行希尔排序*/printf("\nThe result of Shell's sorting for the array is\n");for(i=1;i<=10;i++)printf("%d ",a[i]); /*输出排序后的结果*/getche();}
程序运行的结果如下图所示:
实例的分析:
1.函数中的子序列应用的是优化版的冒泡排序,详细请见数据结构12。
0 0
- 数据结构13-排序方法之希尔排序的实例
- 数据结构之希尔排序
- 数据结构之希尔排序
- 数据结构之希尔排序
- 数据结构之希尔排序
- 数据结构--排序之希尔排序
- 数据结构之排序:希尔排序
- 数据结构之希尔排序的Java实现
- 数据结构10-排序方法之直接插入排序的实例
- 数据结构11-排序方法之选择排序的实例
- 数据结构12-排序方法之冒泡排序的实例
- 数据结构14-排序方法之快速排序的实例
- 数据结构学习之 希尔排序
- python数据结构之希尔排序
- 【希尔排序】数据结构实验之排序六:希尔排序
- 数据结构之排序之希尔排序
- 【数据结构之排序3】希尔排序
- 数据结构之插入排序与希尔排序
- cocos2dx 3.2 打包 滚动层不正常
- 如何添加真机调试的iOS设备
- 前端学习实践笔记--JavaScript深入【1】
- 前端学习实践笔记--JavaScript深入【2】
- HDU 3217 Health(状压DP)
- 数据结构13-排序方法之希尔排序的实例
- 【玩转cocos2d-x之二十六】数据结构CCDictionary
- .net 首字母大小写转换
- JUnit4.8.2源代码分析-2 org.junit.runner.Request
- 宠物精灵2-卡片类连连看游戏
- 用3个步骤实现响应式网页设计
- java线程池笔记
- WEB 文件下载
- JCIP_4_01_扩展现有安全类