栈的介绍和使用(算法)

栈最大的特点是先进先出。利用这个特点应用于我们的日常生活会有很大的便利。下面我们一起来看看吧。

class Solution {

public:

int calculate(string s) {

//用数组来模拟栈

vector<int> st;

int i=0,n=s.size();

char op='+';

while(i<n){

if(si==' ') i++;

else if(si>='0'&&si<='9'){

int tmp=0;

while(i<n&&si>='0'&&si<='9')

tmp=tmp*10+(si++-'0');

if(op=='+') st.push_back(tmp);

else if(op=='-') st.push_back(-tmp);

else if(op=='*') st.back()*=tmp;

else st.back()/=tmp;

}else{

op=si;

i++;

}

}

int sum=0;

for(auto e: st){

sum+=e;

}

return sum;

}

};

class Solution {

public:

string decodeString(string s) {

stack<int> nums;

stack<string> st;

st.push("");

int i=0,n=s.size();

while(i<n){

if(si>='0'&&si<='9'){

int tmp=0;

while(si>='0'&&si<='9'){

tmp=tmp*10+(si++-'0');

}

nums.push(tmp);

}else if(si=='['){

i++;

string tmp="";

while(si>='a'&&si<='z'){

tmp+=si++;

}

st.push(tmp);

}else if(si==']'){

string tmp=st.top();

st.pop();

int k=nums.top();

nums.pop();

while(k--){

st.top()+=tmp;

}

i++;

}else{

string tmp;

while(i<n&&si>='a'&&si<='z'){

tmp+=si++;

}

st.top()+=tmp;

}

}

return st.top();

}

};

class Solution {

public:

bool validateStackSequences(vector<int>& pushed, vector<int>& popped) {

int n=popped.size();

stack<int> result;

int i=0;

for(auto e: pushed){

result.push(e);

while(result.size()&&result.top()==poppedi){

result.pop();

i++;

}

}

return i==n;

}

};

相关推荐
不会就选b10 分钟前
算法日常・每日刷题--<二分查找>1
算法
Chen_harmony13 分钟前
二、顺序表
数据结构
「維他檸檬茶」15 分钟前
大模型算法学习2026.6.13
学习·算法
叫我:松哥19 分钟前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask
BAGAE31 分钟前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
happymaker062635 分钟前
LeetCodeHor100——438.找到字符串中所有的字母异位词
算法
西安邮电大学41 分钟前
有关栈的经典算法题
java·后端·其他·算法·面试
h_a_o777oah1 小时前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
兰令水1 小时前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球1 小时前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习