日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
LeetCode之有效的括號(hào)

前言

LeetCode 算法到目前我們已經(jīng)更新了 19 期,我們會(huì)保持更新時(shí)間和進(jìn)度(周一、周三、周五早上 9:00 發(fā)布),每期的內(nèi)容不多,我們希望大家可以在上班路上閱讀,長(zhǎng)久積累會(huì)有很大提升。

不積跬步,無以至千里;不積小流,無以成江海,Swift社區(qū) 伴你前行。

難度水平:簡(jiǎn)單

1. 描述

給定一個(gè)只包括 '(',')','{','}','[',']' 的字符串 s ,判斷字符串是否有效。

有效字符串需滿足:

左括號(hào)必須用相同類型的右括號(hào)閉合。

左括號(hào)必須以正確的順序閉合。

2. 示例

示例 1

輸入:s = "()"
輸出:true




示例 2

輸入:s = "()[]{}"
輸出:true




示例 3

輸入:s = "(]"
輸出:false




示例 4

輸入:s = "([)]"
輸出:false




示例 5

輸入:s = "{[]}"
輸出:true




約束條件:

  • 1 <= s.length <= 104
  • s 僅由括號(hào) '()[]{}' 組成

3. 答案

class ValidParentheses {
func isValid(_ s: String) -> Bool {
var stack = [Character]()

for char in s {
if char == "(" || char == "[" || char == "{" {
stack.append(char)
} else if char == ")" {
guard stack.count != 0 && stack.removeLast() == "(" else {
return false
}
} else if char == "]" {
guard stack.count != 0 && stack.removeLast() == "[" else {
return false
}
} else if char == "}" {
guard stack.count != 0 && stack.removeLast() == "{" else {
return false
}
}
}

return stack.isEmpty
}
}




  • 主要思想:使用堆棧查看 peek 左大括號(hào)是否對(duì)應(yīng)于當(dāng)前右大括號(hào)。
  • 時(shí)間復(fù)雜度:O(n)
  • 空間復(fù)雜度:O(n)

該算法題解的倉(cāng)庫(kù):LeetCode-Swift[2]

點(diǎn)擊前往 LeetCode[3] 練習(xí)

參考資料

[1] @故胤道長(zhǎng): https://m.weibo.cn/u/1827884772

[2] LeetCode-Swift: https://github.com/soapyigu/LeetCode-Swift

[3] LeetCode: https://leetcode.com/problems/valid-parentheses


網(wǎng)頁名稱:LeetCode之有效的括號(hào)
鏈接地址:http://www.dlmjj.cn/article/djioosh.html