真的破防了 2022-08-02 19:34 采纳率: 71.4%
浏览 55
已结题

java中 方法里面无法使用自减运算符

在写leetcode第22题,括号生成时,发现方法中的变量不能使用自减(--)否则报错或异常
必须把方法中改成-1,才可以运行,不知道是什么原因,还是特性,只是很好奇

报错内容 Exception in thread "main" java.lang.StackOverflowError
at java.base/java.lang.invoke.StringConcatFactory$MethodHandleInlineCopyStrategy.newArray(StringConcatFactory.java:1605)

想知道是什么原因
视频中的代码是看b站上学习的 up EdwardShi,hot100中的第22题

错误的代码
import java.util.ArrayList;
import java.util.List;

public class Test1 {
    public static void main(String[] args) {
        int n = 3;
        List<String> res = new ArrayList<>();
        if (n == 0) {
            return ;
        }
        helper(res, " ", n, n);
        System.out.println(res);
    }
    public static void helper(List<String> res, String s, int left, int right) {
        if (left > right) {
            return;
        }
        // 当左右需要输出括号的值都为0时就代表全部添加完
        if (left == 0 && right == 0) {
            res.add(s);
            return;
        }
        if (left > 0) {
            helper(res, s + "(", left--, right);
        }
// 在两个if里helper方法中,变量不能自减(--)否则会异常,在leetcode提交是超出内存限制
        if (right > 0) {
            helper(res, s + ")", left, right--);
        }
    }
}
  • 写回答

2条回答 默认 最新

  • 天上太阳有九个 2022-08-02 21:04
    关注

    left-- 会先执行该语句的计算任务然后再自身-1
    在迭代传递时,传递的不是left-1而是left,
    所以永远计算的是helper(,,left,right)导致StackOverflowError

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 8月11日
  • 已采纳回答 8月3日
  • 创建了问题 8月2日

悬赏问题

  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解