20. 有效的括号
✔做题思路 or 感想:
-
做这种对称匹配类问题,相当适合用栈来解
-
有三种不匹配情况
-
{]
,单纯不匹配 -
{{}
左边多了 -
[]]
右边多了遇到这三种直接
return false
就好
class Solution { public: bool isValid(string s) { stack<char> st; for (int i = 0; i < s.size(); i++) { if (s[i] == '(')st.push(')'); //加入元素 else if (s[i] == '{')st.push('}'); else if (s[i] == '[')st.push(']'); else if (st.empty() || st.top() != s[i])return false; //如果单纯不匹配或者右边多了,则无 else st.pop(); } return st.empty(); //如果左边多了,则到最后栈不是空的,所以这里要栈为空,才能顺利对称 } };
-
-
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端