希尔排序

栏目: 编程工具 · 发布时间: 6年前

Java代码实现

public static void shellSort(int[] arr) {
        int len = arr.length;
        //增量, 选择合适的增量有助于性能提升
        int inc = 2;
        // 步长
        int step = len / inc;
        for (; step > 0; step /= inc) {
            //从第r个元素,逐个对其所在组进行直接插入 排序 操作
            for (int r = step; r < len; r ++) {
                // 左边要比较的值
                int l = r - step;
                int insertValue = arr[r];
                for (; l >= 0 && insertValue < arr[l]; l -= step) {
                    arr[l + step] = arr[l];
                }
                arr[l + step] = insertValue;
            }
        }
    }

GoLang 代码实现

func shellSort(arr []int) {
    len := len(arr)
    // 增量
    inc := 2
    // 步长
    step := len / inc
    for ; step > 0; step /= inc {
        for r := step; r < len; r ++ {
            // 最小下标为0
            l := r - step
            tmp := arr[r]
            for ; l >= 0 && tmp < arr[l]; l -= step {
                arr[l+step] = arr[l]
            }
            arr[l+step] = tmp
        }
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

设计模式之禅

设计模式之禅

秦小波 / 机械工业出版社 / 2010年3月 / 69.00元

如果说“四人帮”的《设计模式》是设计模式领域的“圣经”,那么之后出版的各种关于设计模式的书都可称之为“圣经”的“注释版”或“圣经的故事”。本书是得道者对“圣经”的“禅悟”,它既不像“圣经”那样因为惜字如金、字字珠玑而深奥、晦涩和难懂,又比“圣经”的“注释版”更深刻和全面、更通俗和生动、更接近开发者遇到的实践场景,更具指导性。本书兼收并蓄、博采众长,也许是设计模式领域里的下一个里程碑之作。 全......一起来看看 《设计模式之禅》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具