maskainv 2010-06-30 16:18
浏览 458
已采纳

return后函数继续执行...

以下是我自己随便写的一段代码,想实现2分法查找

/**
* 二分法查找
*
* @param a
* 被查数组
* @param x
* 目标整数
* @return x在a中的index值
*/
public int findBy2(int[] a, int x, int direct) {
int n = a.length / 2;
index += direct * n;
System.out.println("迭代后的index值是:" + index);
if (a.length % 2 == 0) { // 数组长度为偶数 直接平分
if (x == a[n]) {
return index;
} else {
if (x > a[n]) {
int[] b = Arrays.copyOfRange(a.clone(), n, a.length);
findBy2(b, x, 1);
} else if (x == a[n - 1]) {
return index - 1;
} else { // x<a[n]
int[] b = Arrays.copyOfRange(a.clone(), 0, n);
findBy2(b, x, -1);
}
}
} else { // 数组长度为奇数 应该取中间值 再平分
if (x == a[n]) {

        }
    }
    return 0;
}

public int findBy2(int[] a, int x) {
    return findBy2(a, x, 1);
}


public static void main(String[] args) {
    MyMath my = new MyMath();
    int[] a = new int[] { 0, 1, 2, 3, 4, 5, 6, 7 };
    System.out.println(my.findBy2(a, 6));
}

但运行的时候发现在第二次迭代的时候 return后跳到后面的if语句里面了,让我非常郁闷。
有人指点一下吗?

  • 写回答

1条回答 默认 最新

  • myali88 2010-06-30 16:45
    关注

    那是因为你有递归调用,第二次的return是返回到第二次调用findBy2的堆栈上,然后返回到前一次调用,然后返回。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵