代码随想录算法训练营第十一天 | 20.有效的括号 1047.删除字符串中的所有相邻 重复项 150.逆波兰表达式求值
20. 有效的括号
思路:遍历字符串,如果栈不为空,则进行匹配
如果匹配则出栈,否则入栈
如果栈为空,直接入栈
遍历结束后栈为空则说明全部匹配,否则没有全部匹配
class Solution {
public:
bool isValid(string s) {
stack<char> st;
for(char ch : s) {
if(!st.empty()) {
if(st.top() == '(' && ch == ')') st.pop();
else if(st.top() == '[' && ch == ']') st.pop();
else if(st.top() == '{' && ch == '}') st.pop();
else st.push(ch);
} else {
st.push(ch);
}
}
return st.empty();
}
};
1047. 删除字符串中的所有相邻重复项
思路:同上一题,不过这次是字符相同出栈
class Solution {
public:
string removeDuplicates(string s) {
stack<char> st;
for(char ch : s) {
if(!st.empty()) {
if(st.top() == ch) st.pop();
else st.push(ch);
} else {
st.push(ch);
}
}
int size = st.size();
s.resize(size);
while(!st.empty()) {
s[--size] = st.top();
st.pop();
}
return s;
}
};
150. 逆波兰表达式求值
后缀表达式,直接用栈来解,唯一要注意的就是先出栈的元素是表达式右边的操作数
class Solution {
public:
int evalRPN(vector<string>& tokens) {
stack<int> st;
int ans;
int rhs;
int lhs;
for(string s : tokens) {
if(s != "+" && s != "*" && s != "-" && s != "/") {
st.push(stoi(s));
} else {
rhs = st.top();
st.pop();
lhs = st.top();
st.pop();
switch (s[0]) {
case '+' :
ans = lhs + rhs;
break;
case '-' :
ans = lhs - rhs;
break;
case '*' :
ans = lhs * rhs;
break;
case '/' :
ans = lhs / rhs;
break;
}
st.push(ans);
}
}
return st.top();
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?