排序—希尔排序
发布日期:2021-10-17 00:06:05
浏览次数:13
分类:技术文章
本文共 1402 字,大约阅读时间需要 4 分钟。
要说希尔排序首先要明白插入排序, :
插入排序是直接对数组进行循环插入,二希尔排序是先把数组分隔成多个特别的数组,然后再对分割出来的数组进行插入排序。
该如何对数组进行分割呢? 取一个步长 step =array.length,,然后for(int i =0;i<array.length;i+=step)为一个数组。 注意step是变化的, 每循环一次step要整除以2.
运行示例:
原数组: 21、8、2、18、0、9、27、12、5、24、13、
第0次循环排序结果: 9、8、2、18、0、13、27、12、5、24、21、 第1次循环排序结果: 9、8、2、18、0、13、27、12、5、24、21、 第2次循环排序结果: 9、8、2、18、0、13、27、12、5、24、21、 第3次循环排序结果: 9、8、2、5、0、13、27、12、18、24、21、 第4次循环排序结果: 9、8、2、5、0、13、27、12、18、24、21、 第5次循环排序结果: 0、8、2、5、9、13、18、12、21、24、27、 第6次循环排序结果: 0、5、2、8、9、12、18、13、21、24、27、 第7次循环排序结果: 0、2、5、8、9、12、13、18、21、24、27、public void shellSort(int[] array) { printArray("原数组:", array); int num; // 步长循环至1 for (int step = array.length / 2; step > 0; step /= 2) { // 相邻步长之间的长度 for (int i = 0; i < step; i++) { // 此时可以确定出来一个数组,对此数组进行插入排序 for (int j = i; j < array.length; j += step) { num = array[j]; for (int m = j - step; m >= 0; m -= step) { if (num > array[m]) { array[m + step] = num; break; } else { array[m + step] = array[m]; array[m] = num; } } } printArray("第" + time++ + "次循环排序结果: ", array); } } }
转载地址:https://blog.csdn.net/sulan2131/article/details/69053497 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过,博主的博客真漂亮。。
[***.116.15.85]2024年03月21日 16时48分31秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
《定投十年财务自由》书中精髓:我们如何通过定投获得更高的收益?
2019-04-26
《彼得·林奇教你理财》书中精髓:如何开始投资,以及我们到底该投资什么?
2019-04-26
《货币简史》书中的精髓:货币产生的起源是什么?货币又是如何发展起来的?
2019-04-26
《摩根财团》精髓:摩根财团与时俱进,在不同时代扮演不同角色,始终走在时代的前列
2019-04-26
《朝贡贸易与仗剑经商》精髓:古代中国朝廷不保护商人,将中国商人置于西方势力的仗剑经商之下
2019-04-26
《华尔街之狼》精髓:摔倒并不是坏事,就怕你因此放弃。
2019-04-26
《微观动机与宏观行为》精髓:个人的微观动机,是如何影响宏观行为结果的?
2019-04-26
《金融的本质》书中的精髓:金融危机是如何产生的?以及美联储是如何应对金融危机的?
2019-04-26
《周期》书中的精髓:如何利用周期,掌握世界的发展趋势,实现财富积累。
2019-04-26
《伟大的博弈》书中的精髓:华尔街是如何从一条小街,一步步发展为世界金融中心的。
2019-04-26
《逃不开的经济周期》书中的精髓:经济周期是推动创新变革和经济增长以及复兴的关键力量。
2019-04-26
《动物精神》书中的精髓:人类的非理性面影响经济决策,这些有可能是金融危机的根源。
2019-04-26
《巴菲特法则》书中的精髓:用好巴菲特企业前景投资法则,股票投资稳赚不赔。
2019-04-26
《战胜华尔街》书中的精髓:业余投资者如何根据行业特点选好股票,赚得比专业的投资者还要多?
2019-04-26