查找折半java代码 折半查找代码实现

java折半查找数组元素public class d{
public static int find(int[] arr){
int start=0,end=arr.length-1,mid=(start end)/2;
while(start=end){
if(arr[mid]99){
start=mid 1;
}
else if(arr[mid]==99){
return mid;
}
else {
end=mid-1;
}
mid=(start end)/2;
}
return -1;
}
public static void main(String[] args){
int[] arr={11,22,33,44,99,101};
System.out.println(find(arr));
}
}
用java实现,通过键盘输入一个数 , 在排序后的数组中 , 采用折半查找法查找该数在数组中的 位置 。import java.util.Scanner;
public class Test {
static int bsearch( int[] a, int v ) {
int l, r;
l = 0; r = a.length-1;
while ( l = r ) {
int m = (l r)/2;
if ( a[m] == v ) return m; else
if ( a[m]v ) r = m-1; else
if ( a[m]v ) l = m 1;
}
return -1;
}
public static void main( String[] args ) {
int[] a = { 1,3,5,7,9 };
Scanner sc = new Scanner(System.in);
System.out.println("请输入您要找的值:");
int num = sc.nextInt();
System.out.println( "找到 "num" 在数组的位置是:"bsearch( a, num ));
}
}
用二分法查找(折半查找)java二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法 。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列 。
二分查找优缺点
优点是比较次数少 , 查找速度快,平均性能好;
其缺点是要求待查表为有序表,且插入删除困难 。
因此,折半查找方法适用于不经常变动而查找频繁的有序列表 。
使用条件:查找序列是顺序结构,有序 。
过程
首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较 , 如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表 。重复以上过程 , 直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功 。
【查找折半java代码 折半查找代码实现】利用循环的方式实现二分法查找
public class BinarySearch {
public static void main(String[] args) {
// 生成一个随机数组int[] array = suiji();
// 对随机数组排序Arrays.sort(array);
System.out.println("产生的随机数组为: "Arrays.toString(array));
System.out.println("要进行查找的值: ");
Scanner input = new Scanner(System.in);
// 进行查找的目标值int aim = input.nextInt();
// 使用二分法查找int index = binarySearch(array, aim);
System.out.println("查找的值的索引位置: "index);
}
/*** 生成一个随机数组*
* @return 返回值,返回一个随机数组*/
private static int[] suiji() {
// random.nextInt(n) m返回m到m n-1之间的随机数int n = new Random().nextInt(6)5;
int[] array = new int[n];
// 循环遍历为数组赋值for (int i = 0; iarray.length; i) {
array[i] = new Random().nextInt(100);
}
return array;
}
/*** 二分法查找---循环的方式实现*
* @param array 要查找的数组* @param aim 要查找的值* @return 返回值,成功返回索引,失败返回-1*/
private static int binarySearch(int[] array, int aim) {
// 数组最小索引值int left = 0;
// 数组最大索引值int right = array.length - 1;
int mid;
while (left = right) {
mid = (leftright) / 2;
// 若查找数值比中间值小 , 则以整个查找范围的前半部分作为新的查找范围if (aimarray[mid]) {
right = mid - 1;
// 若查找数值比中间值大,则以整个查找范围的后半部分作为新的查找范围} else if (aimarray[mid]) {
left = mid1;
// 若查找数据与中间元素值正好相等,则放回中间元素值的索引} else {
return mid;
}
}
return -1;
}}
运行结果演示:
由以上运行结果我们得知 , 如果要查找的数据在数组中存在,则输出该数据在数组中的索引;如果不存在则输出 -1 , 也就是打印 -1 则该数在数组中不存在,反之则存在 。
四、利用递归的方式实现二分法查找
public class BinarySearch2 {
public static void main(String[] args) {
// 生成一个随机数组int[] array = suiji();
// 对随机数组排序Arrays.sort(array);
System.out.println("产生的随机数组为: "Arrays.toString(array));
System.out.println("要进行查找的值: ");
Scanner input = new Scanner(System.in);
// 进行查找的目标值int aim = input.nextInt();
// 使用二分法查找int index = binarySearch(array, aim, 0, array.length - 1);
System.out.println("查找的值的索引位置: "index);
}
/*** 生成一个随机数组** @return 返回值,返回一个随机数组*/
private static int[] suiji() {
// Random.nextInt(n) m返回m到m n-1之间的随机数int n = new Random().nextInt(6)5;
int[] array = new int[n];
// 循环遍历为数组赋值for (int i = 0; iarray.length; i) {
array[i] = new Random().nextInt(100);
}
return array;
}
/*** 二分法查找 ---递归的方式** @param array 要查找的数组* @param aim要查找的值* @param left左边最小值* @param right 右边最大值* @return 返回值,成功返回索引 , 失败返回-1*/
private static int binarySearch(int[] array, int aim, int left, int right) {
if (aimarray[left] || aimarray[right]) {
return -1;
}
// 找中间值int mid = (leftright) / 2;
if (array[mid] == aim) {
return mid;
} else if (array[mid]aim) {
//如果中间值大于要找的值则从左边一半继续递归return binarySearch(array, aim, left, mid - 1);
} else {
//如果中间值小于要找的值则从右边一半继续递归return binarySearch(array, aim, mid1, array.length-1);
}
}}
运行结果演示:
总结:
递归相较于循环,代码比较简洁 , 但是时间和空间消耗比较大,效率低 。在实际的学习与工作中 , 根据情况选择使用 。通常我们如果使用循环实现代码只要不是太繁琐都选择循环的方式实现~
关于查找折半java代码和折半查找代码实现的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

    推荐阅读