22括号生成

看题目描述

这样的话,首先返回的东西是一个列表<String>
看到有关括号匹配括号生成我们自然而然想到了,栈
Stack<Character>

n>=1 <=8所以我们不需要考虑栈为空的可能

那么思路如下,如果括号是左括号,丢进去,然后如果是又括号,那么就要考虑前面,那么可以用到stack的push和pop方法

首先它题目里面只给我们一个n然后那么我们栈空间需要2n

然后所有可能也就是我们需要去遍历C2n n

n=1 遍历 2次

n=2 遍历 6次

...高中数学基本问题

排列组合

但是在java里面并没有这个样的函数,至少我还不知道

那么我们就考虑用递归

但是这个思路好像有点麻烦,还要鉴权

新的思路是这样的

这个题目的鉴权条件没那么复杂

根本上只需要左括号数量大于等于右括号即可

那么这种

((()))

Java 复制代码
class Solution {

    public List<String> generateParenthesis(int n) {

        List<String> list=new ArrayList<>();

        backtrack("",0,0,n);

        return list;

    }

    private void backtrack(String current,int left,int right,int max)

    {

        if(current.length()==max*2)

        {

            list.add(current);

            return;

        }

        else

        {

            if(left<max)

            {

                backtrack(current+'(',left+1,right,max);

                //加左括号的方式会到函数里面去了,如果不加左括号就会掉出来加右括号了,但是此时主程序还将继续执行,探索右括号的可能

            }

            if(right<left)

            {

                backtrack(current+')',left,right+1,max);

            }

            //这两个条件导致不会大于max*2

            //但是这两个条件一定会把所有可能返回吗?还得想想,答案是能返回的,回溯发这边

        }

    }

}

这里我出了点问题,就是把那个list去变成了局部变量所以呢

我们现在去改改

Java 复制代码
class Solution {

    List<String> list=new ArrayList<>();

    public List<String> generateParenthesis(int n) {

        backtrack("",0,0,n);

        return list;

    }

    private void backtrack(String current,int left,int right,int max)

    {

        if(current.length()==max*2)

        {

            list.add(current);

            return;

        }

        else

        {

            if(left<max)

            {

                backtrack(current+'(',left+1,right,max);

                //加左括号的方式会到函数里面去了,如果不加左括号就会掉出来加右括号了,但是此时主程序还将继续执行,探索右括号的可能

            }

            if(right<left)

            {

                backtrack(current+')',left,right+1,max);

            }

            //这两个条件导致不会大于max*2

            //但是这两个条件一定会把所有可能返回吗?还得想想,答案是能返回的,回溯发这边

        }

    }

}
相关推荐
清心歌21 分钟前
CopyOnWriteArrayList 实现原理
java·开发语言
Java成神之路-43 分钟前
通俗易懂理解 Spring MVC 拦截器:概念、流程与简单实现(Spring系列16)
java·spring·mvc
zhanghongbin0144 分钟前
AI 采集器:Claude Code、OpenAI、LiteLLM 监控
java·前端·人工智能
计算机毕设vx_bysj68691 小时前
【免费领源码】77196基于java的手机银行app管理系统的设计与实现 计算机毕业设计项目推荐上万套实战教程JAVA,node.js,C++、python、大屏数据可视化
java·mysql·智能手机·课程设计
忘梓.1 小时前
墨色规则与血色节点:C++红黑树设计与实现探秘
java·开发语言·c++
hhh3u3u3u1 小时前
Visual C++ 6.0中文版安装包下载教程及win11安装教程
java·c语言·开发语言·c++·python·c#·vc-1
星河耀银海1 小时前
C++ 模板进阶:特化、萃取与可变参数模板
java·开发语言·c++
格鸰爱童话1 小时前
向AI学习项目技能(五)
java·学习
程序员萌萌1 小时前
Java之mysql实战讲解(三):聚簇索引与非聚簇索引
java·mysql·聚簇索引
好家伙VCC1 小时前
**发散创新:基于Python与ROS的机器人运动控制实战解析**在现代机器人系统开发中,**运动控制**是实现智能行为的核心
java·开发语言·python·机器人