算法leetcode|20. 有效的括号(rust重拳出击)
Posted 二当家的白帽子
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法leetcode|20. 有效的括号(rust重拳出击)相关的知识,希望对你有一定的参考价值。
文章目录
20. 有效的括号:
给定一个只包括 '('
,')'
,''
,''
,'['
,']'
的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。
样例 1:
输入:
s = "()"
输出:
true
样例 2:
输入:
s = "()[]"
输出:
true
样例 3:
输入:
s = "(]"
输出:
false
提示:
- 1 <= s.length <= 104
s
仅由括号'()[]'
组成
原题传送门:
https://leetcode.cn/problems/valid-parentheses/
分析:
- 面对这道算法题目,二当家的陷入了沉思。
- 最开始考虑右括号出现在左括号之后就可以了,所以可以计数,但是由于有三种括号,交错出现的时候就不对了。
- 试想有效的括号字符串,一定有最内层的括号对可以互相匹配,删除匹配的括号对后,接着找最内层,递归或者循环查找直到字符串为空或者没有可以匹配的括号对,这种方式需要查找多次,但是有优化的点。
- 另外借用上面的思想可以使用数据结构实现,右括号出现时一定与前面出现的左括号匹配,所以可以考虑用栈解决,匹配好的就出栈,待匹配的就入栈,最后栈空就是有效的括号字符串。
题解:
rust
impl Solution
pub fn is_valid(s: String) -> bool
if s.len() & 1 == 1 return false;
let mut stk = vec![];
for c in s.into_bytes()
match c
b'(' => stk.push(c + 1),
b'[' | b'' => stk.push(c + 2),
_ => if Some(c) != stk.pop() return false
stk.is_empty()
go
func isValid(s string) bool
if len(s)&1 == 1
return false
var stk []int32
for _, c := range s
switch c
case '(':
stk = append(stk, c+1)
case '[', '':
stk = append(stk, c+2)
default:
if len(stk) == 0 || stk[len(stk)-1] != c
return false
stk = stk[:len(stk)-1]
return len(stk) == 0
c++
class Solution
public:
bool isValid(string s)
if (s.size() & 1 == 1)
return false;
stack<char> stk;
for (char &c: s)
switch (c)
case '(':
stk.push(c + 1);
break;
case '[':
case '':
stk.push(c + 2);
break;
default:
if (stk.empty() || stk.top() != c)
return false;
stk.pop();
break;
return stk.empty();
;
python
class Solution:
def isValid(self, s: str) -> bool:
if len(s) % 2 == 1:
return False
pairs =
")": "(",
"]": "[",
"": "",
stk = list()
for ch in s:
if ch in pairs:
if not stk or stk[-1] != pairs[ch]:
return False
stk.pop()
else:
stk.append(ch)
return not stk
java
class Solution
public boolean isValid(String s)
if ((s.length() & 1) == 1)
return false;
Deque<Character> stk = new LinkedList<>();
for (char c : s.toCharArray())
switch (c)
case '(':
stk.push((char) (c + 1));
break;
case '[':
case '':
stk.push((char) (c + 2));
break;
default:
if (stk.isEmpty() || stk.pop() != c)
return false;
break;
return stk.isEmpty();
非常感谢你阅读本文~
欢迎【点赞】【收藏】【评论】~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~
以上是关于算法leetcode|20. 有效的括号(rust重拳出击)的主要内容,如果未能解决你的问题,请参考以下文章
算法leetcode|32. 最长有效括号(rust重拳出击)