算法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重拳出击)

leetcode算法20.有效的括号

LeetCode 20. 有效的括号

⭐算法入门⭐《栈》简单01 —— LeetCode 20. 有效的括号

LeetCode20——有效的括号

Python描述 LeetCode 20. 有效的括号