Java_实例_递归实现二分查找法


import java.util.Arrays;

/**
 * 递归实现二分查找法
 * @author 肖
 *
 */
public class RankTest {
/**
 * 
 * @param key
 * @param a 数组
 * @return int 索引
 */
    public static int rank(int key, int[] a) {
        return rank(key, a, 0, a.length - 1);
    }

    public static int rank(int key, int[] a, int lo, int hi) {
        if (lo > hi)    return -1;
        int mid = lo + (hi - lo) / 2;
        
        if (key < a[mid])       return rank(key, a, lo, mid - 1);
        else if (key > a[mid])  return rank(key, a, mid + 1, hi);
        else                    return mid;
    }

    public static void main(String[] args) {
        int[] b = {1,3,5,7,9,5,4,13,12,14,15};
        Arrays.sort(b);//排序
        System.out.println(rank(15,b));//查找 15 在 b[] 中的索引位置
    }
}

在调用二分查找法之前必须先将数组排序;

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 查找是在大量的信息中寻找一个特定的信息元素,在计算机应用中,查找是常用的基本运算,例如编译程序中符号表的查找。本文...
    北方蜘蛛阅读 7,974评论 1 4
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 9,086评论 0 15
  • 当它从绿洲变成满眼黄沙,我依然在淌着雨的屋檐底下煮酒喝茶。 当它从寸草不生变成红灯绿酒,我认识了岁月神偷还向他学习...
    加言寺阅读 1,274评论 0 1
  • 文 /莫菲 好几次,从他打工的便利店门前经过,可挣扎了很久,却还是鼓不足勇气,踏进门前,就连装作巧遇,也做不来。 ...
    爱怼啤的西踢踢阅读 1,235评论 1 0
  • 每天入睡前, 请认真地对自己说, 把一切杂念全部放下。 现在只做一件事, 一件除了此刻就没有机会再做的事。 什么都...
    小剧在成长阅读 1,202评论 3 6