求各位大神解答,为什么这个方法会递归失败?

求各位大神解答,为什么这个方法会递归失败?

问题描述:

public static int BinarySearch_Res(int[] iArr, int x,int y){
			int flag=-1,high=iArr.length,low=0;
		while (iArr[y] != x) {
			high = iArr[y] > x ? y - 1 : high;
			low = iArr[y] < x ? y + 1 : low;
			y = (high + low) / 2;
			BinarySearch_Res(iArr, x, y);
		}
			flag=y;
		return flag;
		
	}

你这个二分问题很大,思路都有问题,建议你先参考这个,先看懂了,再背着写。


	public static int recursionBinarySearch(int[] arr,int key,int low,int high){
		
		if(key < arr[low] || key > arr[high] || low > high){
			return -1;				
		}
		
		int middle = (low + high) / 2;			//初始中间位置
		if(arr[middle] > key){
			//比关键字大则关键字在左区域
			return recursionBinarySearch(arr, key, low, middle - 1);
		}else if(arr[middle] < key){
			//比关键字小则关键字在右区域
			return recursionBinarySearch(arr, key, middle + 1, high);
		}else {
			return middle;
		}
        }	

出口没有写对。死循环了。

你这是二分法查找吗?

while (iArr[y] != x) {

改为

while(low>=high){

判断条件写在里面,否则查不到的时候会变成死循环。

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632