折半插入排序的代码实现(java语言)

30 篇文章 0 订阅
22 篇文章 0 订阅

折半插入排序(算法思想在注释中)

/**
 * className:Sort
 *
 * @author:zjl
 * @version:0.1
 * @date:2020/8/615:17
 * @since:jdk1.8
 */
public class Sort {
    //测试
    public static void main(String[] args) {
        int R[] = {1,5,9,6,2,3,8,4,7};
        int[] ints = binarySort(R);
        for (int i = 0; i < ints.length; i++) {
            System.out.print(ints[i]+" ");
        }
    }
    //折半插入排序
    public static int[] binarySort(int R[]){
        for (int i = 1; i < R.length; i++) {
            int temp = R[i];//暂存待插入元素
            //获取要插入的位置前一个元素的索引indexPre
            int indexPre = biSearchGetIndex(R, i - 1, temp);
            for (int j=i-1;j>indexPre;j--) {
                R[j+1]=R[j]; //元素后移
            }
            R[indexPre+1] = temp; //插入
        }
        return R;
    }

    /**
     *折半查找思想寻找插入位置的前一个元素的索引indexPre
     * @param R 待排序列
     * @param last 待排序列中已经排好顺序的子序列的最后一个元素的索引
     * @param num 待插入元素
     * @return
     */
    public static int biSearchGetIndex(int R[],int last,int num ){
            int i,j;
            i = 0;
            j = last;
            while (j>=i){
                int temp = (i+j)/2;
                if(R[temp]>num){
                    j=temp-1;
                }else {
                    i=temp+1;
                }
            }
        return j;
    }
}

测试结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值