真的破防了 2022-08-02 19:34 采纳率: 62.5%
浏览 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日

悬赏问题

  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 R语言卸载之后无法重装,显示电脑存在下载某些较大二进制文件行为,怎么办
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?
  • ¥15 关于#vue.js#的问题:修改用户信息功能图片无法回显,数据库中只存了一张图片(相关搜索:字符串)
  • ¥15 texstudio的问题,