2019年6月4日第六次练习(20 有效的括号)

本文探讨了使用栈和哈希表解决有效括号字符串问题的两种方法。通过对比暴力解法与高级哈希实现,强调了哈希方法的代码简洁性和易于扩展性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

20 有效的括号

大致意思就是判断括号是否成对,这在数据结构中是学习栈的时候给的例题,所以这里应该是应用栈这个数据结构进行解题。
写出来是这样的,纯属暴力、小白写法.

class Solution {
public:
    bool isValid(string s) {
        if(s.empty()) return true;
    	stack<char> myStack;
    	for(int i=0;i<s.size();i++){
    		if(s[i]=='('||s[i]=='{'||s[i]=='['){
    			myStack.push(s[i]);
    			continue;
    		}
            if(myStack.empty())
                return false;
    		if(!myStack.empty()){
    			if(s[i]==')'){
                    char k=myStack.top();
                    if(k!='(')
                        return false;
    			}
    			if(s[i]=='}'){
    				char k=myStack.top();
    				if(k!='{')
    					return false;
    			}
    			if(s[i]==']'){
    				char k=myStack.top();
    				if(k!='[')
    					return false;
    			}
                myStack.pop();

    		}
    	}
        if(!myStack.empty()) 
            return false;
    	return true;
    }
};

在这里插入图片描述
但用这样的思路,大神们都是用哈希实现的:

class Solution {
public:
    bool isValid(string s) {
        if(s.length()%2!=0) return false;//一但是奇数说明不是有效的括号
        map<char,char> wordbook;//建立哈希表
        wordbook.insert(map<char,char>::value_type(')','('));
        wordbook.insert(map<char,char>::value_type(']','['));
        wordbook.insert(map<char,char>::value_type('}','{'));
        stack<char> mystack;//建立栈
        for(int i=0;i<s.length();i++)
        {
            if(s[i]=='['||s[i]=='{'||s[i]=='(')//匹配到左括号
                mystack.push(s[i]);//放入栈中
            else if(s[i]==']'||s[i]=='}'||s[i]==')')//匹配到右括号
            {
                if(mystack.empty()) return false;
                //匹配到右括号,栈中应该存在左括号。否则就是无效的括号
                if(wordbook[s[i]]==mystack.top())//与栈顶元素进行匹配
                {
                    mystack.pop();//匹配成功删除栈顶元素
                    continue;
                }
                else return false;
            }
        }
        if(mystack.empty()) return true;//有效的括号到最后检测结束栈中应没有元素
        else return false;
    }
};

结果如下,效率大致和我的小白解法差不多,但明显代码简洁且易于增长,要学习哈希这种方法。
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值