初级排序算法

  1. 希尔排序:插入排序的升级,有一个increment(元素增量),适用于乱序数组的插入排序
    • increment变化:每次increment = increment/3
    • 优点:代码量小,不需要额外的内存空间
    • 不稳定排序(不会保留原先相等数据的顺序)
// 希尔排序
    public static void ShellSort(int[] a) {
        int len = a.length; 
        int increment = len/3+1;  // 每次排序增量
        while(increment >= 1) {
            for(int i = increment; i<len; i++) {
                for(int j = i; j >= increment && a[j-increment] > a[j]; j-=increment) {
                    int temp = a[j];
                    a[j] = a[j-increment];
                    a[j-increment] = temp;
                }
            }
            increment = increment/3;
        }
    }

学习连接:https://blog.csdn.net/weixin_37818081/article/details/79202115

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. 基本规则 排序类算法模板 Comparable接口 实现了Comparable接口的数据类型:Intege...
    不会code的程序猿阅读 286评论 0 0
  • 本篇文章同时收录在我的个人博客:『算法』之 初级排序算法总结 选择排序 一种最简单的排序算法:首先,找到数组中最小...
    剑弑九幽阅读 326评论 0 0
  • 冒泡排序 选择排序 插入排序 希尔排序 冒泡排序 思想: 比较相邻的元素。如果第一个比第二个大,就交换他们两个。 ...
    YKDog阅读 601评论 0 5
  • 最近,在通过《算法4》这本书来重新学习一下算法,从最初级的排序算法。初级的排序算法有3种:选择排序、插入排序、希尔...
    Jarvis_Huang阅读 293评论 0 0
  • 选择排序:首先找到数组中最小的那个元素,其次将它和数组第一个元素交换位置(如果第一个元素就是最小元素那么它就和自己...
    Mr_ran阅读 238评论 0 0

友情链接更多精彩内容