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这个数字。
BinarySearch为二分搜索法,故查询前需要用sort()方法将数组排序,如果数组没有排序,则结果是不确定的,另外如果数组中含有多个指定值的元素,则无法保证找到的是哪一个.
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。