由於只包含字元的字串』(』,』)』,』』,』[『和』]』,確定輸入字串是有效的。
如果輸入字串有效:
必須使用相同型別的括號關閉左括號。
必須以正確的順序關閉開啟括號。
請注意,空字串也被視為有效。
括號匹配左括號和右括號匹配使用乙個hashmap儲存鍵值對和stack判斷。
直接看**吧。
/**
* 判斷括號是否有效
* @param s
* @return
*/public
boolean
isvalid
(string s)
hashmap
map =
newhashmap
<
>()
; stack
stack =
newstack
<
>()
; map.
put(
'(',
')')
; map.
put(
'[',
']')
; map.
put('')
;char
chars = s.
tochararray()
;for
(int i =
0; i < chars.length; i++
)else
}return stack.
isempty()
;}
如有偏頗,歡迎指正。 括號匹配問題
時間限制 3000 ms 記憶體限制 65535 kb 難度 3 描述 現在,有一行括號序列,請你檢查這行括號是否配對。輸入第一行輸入乙個數n 0輸出 每組輸入資料的輸出佔一行,如果該字串中所含的括號是配對的,則輸出yes,如果不配對則輸出no 樣例輸入 3 樣例輸出 no noyes 基本演算法思...
括號匹配問題
假設表示式中包含三種括號 圓括號 方括號和花括號,它們可以相互巢狀,如 等均為正確的格式,而等為不正確的格式。以下為演算法程式 括號匹配問題 include include int main char ch while ch getchar eof count 0 break case if cou...
括號匹配問題
問題描述 假設表示式中允許包含兩種括號 圓括號與方括號,其巢狀的順序隨意。如 或 等為正確的匹配 而 或者 或者 均為錯誤的匹配。現要求編寫程式,判斷輸入的一行括號是否是匹配的,如果是匹配的,輸出yes,否則輸出no。解題思路 檢驗括號是否是匹配的方法可以用 期待的急迫程度 這個概念來描述。例如考慮...