标题:图灵程序设计丛书——算法Alogrithms(第四版)书里面有关二分法查找的程序 ...
取消只看楼主
mudi
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2018-12-19
结帖率:100%
已结贴  问题点数:10 回复次数:2 
图灵程序设计丛书——算法Alogrithms(第四版)书里面有关二分法查找的程序例子看不懂
想请教下谁看过谢路云翻译的《算法》一书,里面有一个二分查找的算法,用于处理“白名单”问题。

程序代码:
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;
   }
}
搜索更多相关主题的帖子: 算法 查找 int key mid 
2018-12-21 20:25
mudi
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2018-12-19
得分:0 
回复 2楼 林月儿
运行后程序抛出异常,是这条语句:  int[]  whiteList = In.readInts(args[0]);
(In)是书本作者自己写的一个类:这个类的作用时从标准输入、文件输入当中读取字符串或者数字
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 0
    at BinarySearch.main(BinarySearch.java:5)

2018-12-23 09:37
mudi
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2018-12-19
得分:0 
回复 4楼 林月儿
嗯嗯,自己定义了一个整型数组,但是运行都没有反应。
原本作者说可以输出白名单中没有的字符,这个程序貌似没有这样的效果。
2018-12-23 20:50



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-492197-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.438582 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved