希尔算法

本文介绍了一个简单的插入排序算法实现过程,通过一个包含三个随机整数的数组进行演示,并记录了排序过程中元素交换的次数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    //定义变量(算交换的次数)
    private static int  count = 0;

    public static void main(String[] args) {

        //定义一个含有三个数的数组
        int[] array = new int[3];
        System.out.println("排序之前结果为:");
        //随机生成三个数
        for (int i = 0; i < array.length; i++) {
            array[i] =(int)(Math.random()*100);
        }
        //输出生成的三个数
        System.out.println("初始数据");
        for (int a = 0; a < array.length; a++) {
            System.out.print(array[a] + "\t");
        }
        System.out.println("");
        //调用run方法
        run(array);
        //输出交换的次数
        System.out.println(count);
    }

    //run方法  传参数(main方法中定义的数组)
    private static void run(int[] array) {

        //循环数组 从第二个开始
        for (int i = 1; i < array.length; i++) {

            //当前的数值
            int value = array[i];
            //下标前移
            int index = i - 1;
            用while循环判断
            while(index >= 0 && value < array[index]){
                //前一个数赋值给后一个数
                array[index+1] = array[index];
                //下标前移
                 index --;
            }
            当前数赋值给后一个数
            array[index+1] = value;
            System.out.println("第"+i+"次排序结果");
            //循环输出
            for (int k = 0; k < array.length; k++) {
                System.out.print(array[k] + "\t");
            }
            //交换次数+1
            count++;
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值