数组可由Math.random()方法结合循环自动生成一个固定长度的int数组,然后调用Arrays.sort()方法对其排序,然后得到我们想要的有序int数组
第一种方法:不使用递归
import java.util.Arrays;
import java.util.Scanner;
public class Test2 {
public static void main(String[] args) {
int []arr=new int [30];
//循环往数组内转入数据
for(int i=0;iitem){
high=mid-1;
}
if(guess==item){
index=mid;
break;//在猜中了的时候,将while循环停止
}
if(guess
[1, 6, 7, 10, 11, 15, 19, 20, 24, 24, 29, 30, 30, 35, 39, 40, 40, 47, 48, 48, 53, 63, 64, 68, 79, 85, 86, 88, 91, 100]
输入要查找的数:
5
没有找到对应的元素!
[1, 5, 8, 12, 18, 19, 21, 24, 25, 27, 29, 31, 31, 38, 43, 51, 53, 55, 61, 62, 66, 72, 73, 77, 81, 82, 90, 96, 98, 99]
输入要查找的数:
50
没有找到对应的元素!
import java.util.Arrays;
import java.util.Scanner;
public class Test2 {
public static void main(String[] args) {
int []arr=new int [30];
//循环往数组内转入数据
for(int i=0;ihigh){//递归结束条件
return -1;
}
int mid=(low+high)/2;
int guess=arr[mid];//猜不是瞎猜 永远猜数组中间那个数
if(guess>item){
return binarySearch(arr,item,low,mid-1);
}else if(guess==item){
return mid;
}else{
return binarySearch(arr,item,mid+1,high);
}
}
}
运行结果:
[4, 5, 5, 7, 9, 10, 13, 15, 15, 18, 28, 28, 29, 30, 30, 43, 44, 44, 51, 54, 54, 55, 67, 76, 80, 83, 86, 98, 99, 99]
请输入要查找的数:
9
你要找的数的索引为:4
[7, 8, 8, 11, 13, 15, 15, 15, 18, 19, 26, 36, 42, 43, 44, 45, 46, 48, 48, 53, 58, 58, 73, 74, 77, 79, 81, 93, 95, 99]
请输入要查找的数:
1
没有找到要查的数!