插入排序-Shell排序

Shell排序的JAVA实现

import java.util.Arrays;

public class ShellSort {
    public byte[] Sort(byte[] by) {
        int d = by.length;
        while (true) {
            d = d / 2;
            // x表示待排序数组的字段索引位置
            for (int x = 0; x < d; x++) {// 取(增量个数)长度的数据
                // i表示与x对应的增量索引位置
                for (int i = x + d; i < by.length; i = i + d) {// 取增量差处的数据,与初始值比较。
                    int temp = by[i];// 取增量差处的数据
                    int j;// j表示在增量差位置上的字段索引位置
                    for (j = i - d; j >= 0 && temp < by[j]; j = j - d) {// 把值比较大的放到高位
                        by[j + d] = by[j];// 因为temp<by[j],所以j位置的值更大,所以[j]位置的数据需要移动到[j+d]位置上
                    }
                    by[j + d] = (byte) temp;
                }
                System.out.println("希尔排序第" + (x + 1) + "次:" + Arrays.toString(by));
            }
            if (d == 1) {
                break;
            }
        }
        return by;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值