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

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

        }

    }

}
相关推荐
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维1 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子2 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34162 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
恋爱绝缘体12 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
wszy18093 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
wszy18093 小时前
顶部标题栏的设计与实现:让用户知道自己在哪
java·python·react native·harmonyos
乌萨奇也要立志学C++3 小时前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解
数据结构·c++·算法
程序员小假4 小时前
我们来说一下无锁队列 Disruptor 的原理
java·后端