注册 登录
编程论坛 JAVA论坛

图灵程序设计丛书——算法Alogrithms(第四版)书里面有关二分法查找的程序例子看不懂

mudi 发布于 2018-12-21 20:25, 2830 次点击
想请教下谁看过谢路云翻译的《算法》一书,里面有一个二分查找的算法,用于处理“白名单”问题。

程序代码:
import java.util.*;
public class BinarySearch {
   public static void main(String[] args) {
       //以下语句看不懂是什么作用?想请论坛的热心人帮忙解答。
       int[] whiteList = In.readInts(args[0]);
       Arrays.sort(whiteList);
       while(!StdIn.isEmpty()) {
           int key = StdIn.readInt();
           if(rank(key,whiteList) < 0) {
               StdOut.println(key);
           }                                                      

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

       }
       return -1;
   }
}
4 回复
#2
林月儿2018-12-22 23:05
跑过吗,这段代码
#3
mudi2018-12-23 09:37
回复 2楼 林月儿
运行后程序抛出异常,是这条语句:  int[]  whiteList = In.readInts(args[0]);
(In)是书本作者自己写的一个类:这个类的作用时从标准输入、文件输入当中读取字符串或者数字
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
    at BinarySearch.main(BinarySearch.java:5)

#4
林月儿2018-12-23 18:04
改一下呢,自己定义一个字符串数组
#5
mudi2018-12-23 20:50
回复 4楼 林月儿
嗯嗯,自己定义了一个整型数组,但是运行都没有反应。
原本作者说可以输出白名单中没有的字符,这个程序貌似没有这样的效果。
1