LeetCode 括號配對系列

2021-07-31 05:22:12 字數 980 閱讀 6438

20. valid parentheses

題目:判斷輸入字串的括號配對是否合法

思路:棧——當前字元為左括號時入棧,右括號則pop乙個字元,看是否配對。需要注意棧為空的判斷,在pop之前以及最後判斷時。

public class solution 

else

else if(c == ']')

else}}

if(!stack.isempty()) return false;

return true;

}}

22. generate parentheses

題目:輸出所有合法的括號匹配形式

思路:dfs——分別判斷左右括號個數,左括號數小於n,右括號數小於左括號數。有點類似於二叉樹的左右子數。

public class solution 

public void dfs(listret, string sb, int left, int right, int n)

else

if(right < left)}}

}

32. longest valid parentheses

題目:找到最長的合法括號配對子串長度。

思路:棧——沿用20題的思路,但是棧中壓入的是括號的序號,出現配對就彈出。即棧中每兩位之間下表差都是合法的長度,只要找到最大的長度就行。需要注意首尾的判斷。

public class solution 

}stack.push(i);

}int current = len;

if(stack.isempty()) return len;

while(!stack.isempty())

return math.max(ret, current);

}}

還可以用動態規劃來做。

括號配對問題

原文 1.括號匹配的四種可能性 左右括號配對次序不正確 右括號多於左括號 左括號多於右括號 左右括號匹配正確 2.演算法思想 1.順序掃瞄算數表示式 表現為乙個字串 當遇到三種型別的左括號時候讓該括號進棧 2.當掃瞄到某一種型別的右括號時,比較當前棧頂元素是否與之匹配,若匹配,退棧繼續判斷 3.若當...

括號配對問題

描述 現在,有一行括號序列,請你檢查這行括號是否配對。輸入 第一行輸入乙個數n 0 n 100 表示有n組測試資料。後面的n行輸入多組輸入資料,每組輸入資料都是乙個字串s s的長度小於10000,且s不是空串 測試資料組數少於5組。資料保證s中只含有 四種字元 輸出 每組輸入資料的輸出佔一行,如果該...

括號配對問題

時間限制 3000 ms 記憶體限制 65535 kb 難度 3 描述 現在,有一行括號序列,請你檢查這行括號是否配對。輸入第一行輸入乙個數n 0輸出 每組輸入資料的輸出佔一行,如果該字串中所含的括號是配對的,則輸出yes,如果不配對則輸出no 樣例輸入 3 樣例輸出 no noyes 如下 inc...