真的破防了 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 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题