真的破防了 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日

悬赏问题

  • ¥20 easyPoi能否实现下拉多选或者复选框
  • ¥15 网桥在转发帧时,会变帧的源地址和目的地址吗?
  • ¥15 用Multisim设计汽车尾灯控制电路
  • ¥100 求用matlab求解上述微分方程的程序代码
  • ¥15 MAC安装佳能LBP2900驱动的网盘提取码
  • ¥400 微信停车小程序谁懂的来
  • ¥15 ATAC测序到底用什么peak文件做Diffbind差异分析
  • ¥15 安装ubantu过程中第一个vfat 文件挂载失败
  • ¥20 GZ::CTF如何兼容一些靶机?
  • ¥15 etcd集群部署问题