22. Generate Parentheses

Description

Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses.

For example, given n = 3, a solution set is:

[
"((()))",
"(()())",
"(())()",
"()(())",
"()()()"
]

Solution

DFS

class Solution {
    public List<String> generateParenthesis(int n) {
        List<String> parentheses = new ArrayList();
        if (n < 1) return parentheses;
        
        StringBuilder sb = new StringBuilder();
        generateParenthesis(n, n, sb, parentheses);
        return parentheses;
    }
    
    public void generateParenthesis(int left, int right, StringBuilder sb
                                    , List<String> parentheses) {
        if (left < 0 || right < 0 || left > right) {
            return;
        }
        
        if (left == 0 && right == 0) {
            parentheses.add(sb.toString());
            return;
        }
        
        sb.append('(');
        generateParenthesis(left - 1, right, sb, parentheses);
        sb.setCharAt(sb.length() - 1, ')');
        generateParenthesis(left, right - 1, sb, parentheses);
        sb.deleteCharAt(sb.length() - 1);
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铺纽,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子悲伶,更是在濱河造成了極大的恐慌沐兵,老刑警劉巖蛆封,帶你破解...
    沈念sama閱讀 211,948評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拴竹,死亡現(xiàn)場(chǎng)離奇詭異掉奄,居然都是意外死亡晦款,警方通過查閱死者的電腦和手機(jī)炎功,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缓溅,“玉大人蛇损,你說我怎么就攤上這事√彻郑” “怎么了淤齐?”我有些...
    開封第一講書人閱讀 157,490評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)袜匿。 經(jīng)常有香客問我更啄,道長(zhǎng),這世上最難降的妖魔是什么居灯? 我笑而不...
    開封第一講書人閱讀 56,521評(píng)論 1 284
  • 正文 為了忘掉前任祭务,我火速辦了婚禮,結(jié)果婚禮上怪嫌,老公的妹妹穿的比我還像新娘义锥。我一直安慰自己,他們只是感情好岩灭,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,627評(píng)論 6 386
  • 文/花漫 我一把揭開白布拌倍。 她就那樣靜靜地躺著,像睡著了一般川背。 火紅的嫁衣襯著肌膚如雪贰拿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,842評(píng)論 1 290
  • 那天熄云,我揣著相機(jī)與錄音膨更,去河邊找鬼。 笑死缴允,一個(gè)胖子當(dāng)著我的面吹牛荚守,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播练般,決...
    沈念sama閱讀 38,997評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼矗漾,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了薄料?” 一聲冷哼從身側(cè)響起敞贡,我...
    開封第一講書人閱讀 37,741評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎摄职,沒想到半個(gè)月后誊役,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,203評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谷市,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,534評(píng)論 2 327
  • 正文 我和宋清朗相戀三年蛔垢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片迫悠。...
    茶點(diǎn)故事閱讀 38,673評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鹏漆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出创泄,到底是詐尸還是另有隱情艺玲,我是刑警寧澤,帶...
    沈念sama閱讀 34,339評(píng)論 4 330
  • 正文 年R本政府宣布鞠抑,位于F島的核電站板驳,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏碍拆。R本人自食惡果不足惜若治,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,955評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望感混。 院中可真熱鬧端幼,春花似錦、人聲如沸弧满。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽庭呜。三九已至滑进,卻和暖如春犀忱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背扶关。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評(píng)論 1 266
  • 我被黑心中介騙來泰國打工阴汇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人节槐。 一個(gè)月前我還...
    沈念sama閱讀 46,394評(píng)論 2 360
  • 正文 我出身青樓搀庶,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親铜异。 傳聞我的和親對(duì)象是個(gè)殘疾皇子哥倔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,562評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,738評(píng)論 0 33
  • Given n pairs of parentheses, write a function to generat...
    Jeanz閱讀 257評(píng)論 0 0
  • 插入排序 插入排序的靈感也許來自于撲克牌, 將n按照大小插入到0~n-1中, 當(dāng)左邊都排序好了, 整個(gè)數(shù)組也就排序...
    spike15閱讀 767評(píng)論 0 0
  • 潘子的媽媽終于忍不住了揍庄,要來津城看看她未來的兒媳婦咆蒿。兒媳婦要見婆婆,心里直哆嗦蚂子。小旭屬于比較內(nèi)向的人蜡秽,要見婆婆,更...
    毛瀛德閱讀 298評(píng)論 2 0
  • 學(xué)習(xí)心得# 發(fā)現(xiàn)這個(gè)主題寫思維導(dǎo)圖寫得根本停不下來缆镣,內(nèi)容涵蓋了很多之前已經(jīng)學(xué)過了的(重新思考芽突,是不斷完善的結(jié)果)以...
    Arcy_閱讀 221評(píng)論 2 1