摘要:要求返回一個中包含組括號所有可能的符合規(guī)則的組合。例如輸入結(jié)果集應(yīng)當(dāng)是想法輸入的就代表著我們的字符串的組成是個和個。我們需要跟蹤和的使用情況,來判斷下一步的操作是否合法。
題目詳情
Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses.想法輸入一個正整數(shù)n。要求返回一個List
,list中包含n組括號所有可能的符合規(guī)則的組合。如“(())”就屬于符合規(guī)則的組合,“)(()”就屬于不符合規(guī)則的組合。 例如, 輸入 n = 3, 結(jié)果集應(yīng)當(dāng)是:
[
"((()))",
"(()())",
"(())()",
"()(())",
"()()()"
]
輸入的n就代表著我們的字符串的組成是n個"("和n個")"。
聲明一個cur字符串來暫存我們沒次操作獲得的字符串,而我們每次想要將括號加入cur字符串的時候,我們要保證剩余的括號和現(xiàn)有字符串,可以滿足規(guī)則。也就是說,如果我們想加入一個")",我們要保證cur字符串中的")"的數(shù)量小于"("的數(shù)量,否則字符串就不符合規(guī)則了。
我們需要跟蹤"("和")"的使用情況,來判斷下一步的操作是否合法。
解法public ListgenerateParenthesis(int n) { List ans = new ArrayList(); backtrack(ans, "", 0, 0, n); return ans; } public void backtrack(List ans, String cur, int open, int close, int max){ if (cur.length() == max * 2) { ans.add(cur); System.out.println(cur); return; } if (open < max) backtrack(ans, cur+"(", open+1, close, max); if (close < open) backtrack(ans, cur+")", open, close+1, max); }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/68778.html
摘要:復(fù)雜度思路注意的地方,要限制左括號和右括號。每出現(xiàn)一次左括號,就相對于限定了,最多只能出現(xiàn)那么多右括號。所以,為了完成這種限定,用來控制。不然會有的情況出現(xiàn)。 LeetCode[22] Generate Parentheses Given n pairs of parentheses, write a function to generate all combinations of ...
Problem 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: [ ((())), (()()), (())(), ()(()), ...
摘要:當(dāng)右括號和左括號的剩余量均為時,及為一個最終結(jié)果。而則會在直接原來的對象上進(jìn)行修改,其指針仍然指向原來的對象。因此在遞歸的過程中使用一定要注意,對對象的修改不要相互干擾。 題目要求 Given n pairs of parentheses, write a function to generate all combinations of well-formed parentheses....
摘要:而對于右括號,必須前面放了一個左括號,我們才能放一個右括號。所以我們根據(jù)剩余可放置左括號,和剩余可放置右括號,代入遞歸,就可以求解。 Generate Parentheses 最新更新請見:https://yanjia.me/zh/2019/01/... Given n pairs of parentheses, write a function to generate all co...
摘要:前言從開始寫相關(guān)的博客到現(xiàn)在也蠻多篇了。而且當(dāng)時也沒有按順序?qū)懍F(xiàn)在翻起來覺得蠻亂的。可能大家看著也非常不方便。所以在這里做個索引嘻嘻。順序整理更新更新更新更新更新更新更新更新更新更新更新更新更新更新更新更新 前言 從開始寫leetcode相關(guān)的博客到現(xiàn)在也蠻多篇了。而且當(dāng)時也沒有按順序?qū)憽F(xiàn)在翻起來覺得蠻亂的。可能大家看著也非常不方便。所以在這里做個索引嘻嘻。 順序整理 1~50 1...
閱讀 2577·2021-11-22 13:53
閱讀 4085·2021-09-28 09:47
閱讀 870·2021-09-22 15:33
閱讀 820·2020-12-03 17:17
閱讀 3321·2019-08-30 13:13
閱讀 2126·2019-08-29 16:09
閱讀 1183·2019-08-29 12:24
閱讀 2455·2019-08-28 18:14