栈
| #include <stack> |
| class Solution { |
| public: |
| bool isValid(string s) { |
| stack<char> stk; |
| int length = s.length(); |
| if(length==0){ |
| return true; |
| } |
| for(char i : s){ |
| if(i=='(' || i=='{' || i=='['){ |
| stk.push(i); |
| }else{ |
| if(stk.empty()){ |
| return false; |
| }else{ |
| if(i==')'){ |
| char temp = stk.top(); |
| stk.pop(); |
| if(temp!='(') |
| return false; |
| }else if(i=='}'){ |
| char temp = stk.top(); |
| stk.pop(); |
| if(temp!='{'){ |
| return false; |
| } |
| } |
| else{ |
| char temp = stk.top(); |
| stk.pop(); |
| if(temp!='[') |
| return false; |
| } |
| } |
| } |
| } |
| return stk.empty()? true:false; |
| } |
| }; |
map + stack
| class Solution { |
| public: |
| bool isValid(string s) { |
| int length = s.length(); |
| if(length ==0) return true; |
| if(length %2==1) return false; |
| stack<char> stk; |
| unordered_map<char,char> pairs={ |
| {')','('}, |
| {']','['}, |
| {'}','{'} |
| }; |
| for(char ch:s){ |
| if(pairs.count(ch)){ |
| if(stk.empty() || stk.top()!=pairs[ch]) |
| return false; |
| stk.pop(); |
| }else{ |
| stk.push(ch); |
| } |
| } |
| return stk.empty(); |
| } |
| }; |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本