Java希尔排序方法怎么使用
发表于:2025-02-22 作者:千家信息网编辑
千家信息网最后更新 2025年02月22日,这篇文章主要讲解了"Java希尔排序方法怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Java希尔排序方法怎么使用"吧!用希尔排序法对一组数据
千家信息网最后更新 2025年02月22日Java希尔排序方法怎么使用
这篇文章主要讲解了"Java希尔排序方法怎么使用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Java希尔排序方法怎么使用"吧!
用希尔排序法对一组数据由小到大进行排序,数据分别为69、56、12、136、3、55、46、99、88、25。
希尔排序的全过程如下:
代码实现:
/*第九天、希尔排序*/#include#include /*****************************************************************************************希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效 **的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。 **希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少 **每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。 ******************************************************************************************//******************************************* *函数名称:Shsort *参数说明:pDataArray 无序数组指针* iDataNum 无序数据个数 *说明: 希尔排序 ********************************************/ void Shsort(int* pDataArray,int iDateNumn){ int i,j,d; d = iDateNumn / 2; /*确定固定增量值,设为数组长度的一半*/ while(d >= 1) /*增量等于1退出循环*/ { for(i = d;i < iDateNumn;i++) /*数组下标从d开始进行直接插入排序*/ { /*也就是数组的第d+1个元素*/ int temp = pDataArray[i]; /*设置监视哨,元素最右边的位置*/ j = i - d; /*确定要进行比较的元素的最左边位置*/ while((j >= 0) && (temp < pDataArray[j])) /*从后向前,找到比其小的数的位置*/ { pDataArray[j + d] = pDataArray[j]; /*数据右移*/ j -= d; /*向左移动d个位置*/ } if (j != i - d) /*存在比其小的数*/ pDataArray[j + d] = temp; /*在确定的位置插入pDataArray[i]*/ } d = d / 2; }}/******************************************* *函数名称:main*参数说明:无*说明: 主函数 ********************************************/ void main(void){ int pDataArray[10],i; printf("请输入10个数据:\n"); for(i = 0;i < 10;i++) scanf("%d",&pDataArray[i]); Shsort(pDataArray,10); printf("排序后的顺序是:\n"); for(i = 0;i < 10;i++) printf("%5d",pDataArray[i]); printf("\n"); system("pause");}
结果显示:
感谢各位的阅读,以上就是"Java希尔排序方法怎么使用"的内容了,经过本文的学习后,相信大家对Java希尔排序方法怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
排序
希尔
方法
增量
数据
算法
函数
学习
位置
内容
参数
名称
数组
下标
个位
个数
九天
代码
全过程
关键
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
运行php需要数据库支持吗
嘶吼 网络安全
北京的软件开发学校
网络服务器安全控
网络安全移动
服务器是一台专用的计算机
群晖数据库库存清理
锐思数据库中如何查询每股股利
服务器利旧优缺点
新媒体网络技术人员面试
湖北省果子互联网科技有限公司
米尺网络技术怎么样
数据库文件分离后有个锁
腾讯公司的手游服务器
网络安全管理员报考
网络安全所遇到的问题有哪些
边缘融合软件服务器
怎么测试电脑和服务器延迟
软件开发业务员提成
服务器raid有哪些组合
mpa数据库
江苏软件开发口碑推荐
网络安全 教材
北京的软件开发学校
网上手游软件开发
wps怎么筛选新数据库
中国最大的商标注册数据库
网络安全保卫员个人总结
中职学校网络技术基础题库
人口数据库信息一直不更新