java中的BinarySearch的问题

import java.util.*;
public class Sample14_25 {
public static void main(String[] args) {
ArrayList al = new ArrayList();
for(int i=0;i<50;i++){
al.add(Integer.valueOf((int)(Math.random()*100)));
}
System.out.println("输出排序前的数组:");
//Collections.sort(al);
System.out.println(al);
int index = Collections.binarySearch(al, Integer.valueOf(20));
if(index < 0){
System.out.print("不好意思,没有查找到相应的内容");
}else{
System.out.println("恭喜你,找到相应的内容,索引是:"+index+" 是该数组的第"+(index+1)+"个数字。");
System.out.print("{");
for(int i=0;i<al.size();i++){
if(i == index){
System.out.print("["+al.get(i)+"]"+" ");
}else{
System.out.print(al.get(i)+" ");
}
}
System.out.println("}");
}
}
}
程序大意:就是随机产生50个(或10个)100以内的整数,然后看看里面有没有20这个数字,要是有就用[]括起来。如18,22,45,[20],78.....
但是问题是,有时候这个程序并不能找到20,虽然生成的随机数里有20?还有就是随机生成的数字里有两个20,但是一会儿指出来第一个,一会儿指出来第二个。
注:随机生成的数字的个数有时是50个,有时是10个,我是为了方便找到20这个数字。
1.
图片说明
2.
图片说明
3.
图片说明
4.
图片说明
5.
图片说明

我先谢谢各位java师傅们了,谢谢!

查看全部
king_dust
「已注销」
2015/08/23 12:44
  • java
  • 点赞
  • 收藏
  • 回答
    私信
满意答案
查看全部

4个回复