栈的介绍和使用(算法)

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

class Solution {

public:

int calculate(string s) {

//用数组来模拟栈

vector<int> st;

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

char op='+';

while(i<n){

if(s[i]==' ') i++;

else if(s[i]>='0'&&s[i]<='9'){

int tmp=0;

while(i<n&&s[i]>='0'&&s[i]<='9')

tmp=tmp*10+(s[i++]-'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=s[i];

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(s[i]>='0'&&s[i]<='9'){

int tmp=0;

while(s[i]>='0'&&s[i]<='9'){

tmp=tmp*10+(s[i++]-'0');

}

nums.push(tmp);

}else if(s[i]=='['){

i++;

string tmp="";

while(s[i]>='a'&&s[i]<='z'){

tmp+=s[i++];

}

st.push(tmp);

}else if(s[i]==']'){

string tmp=st.top();

st.pop();

int k=nums.top();

nums.pop();

while(k--){

st.top()+=tmp;

}

i++;

}else{

string tmp;

while(i<n&&s[i]>='a'&&s[i]<='z'){

tmp+=s[i++];

}

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()==popped[i]){

result.pop();

i++;

}

}

return i==n;

}

};

相关推荐
不染尘.2 小时前
排序算法详解2
数据结构·c++·算法·排序算法
cm6543202 小时前
C++代码切片分析
开发语言·c++·算法
重生之我是Java开发战士2 小时前
【递归、搜索与回溯】FloodFill算法:图像渲染,岛屿数量,岛屿的最大面积,被围绕的区域,太平洋大西洋水流问题,扫雷游戏,衣橱整理
算法·leetcode·深度优先
YUANQIANG20242 小时前
PPO算法典型思路
算法·机器学习
twc8292 小时前
大模型评估指标简要说明
算法·大模型·bleu
淀粉肠kk2 小时前
【C++】C++11可变参数模板和emplace系列接口
算法
ab1515172 小时前
3.21二刷基础125、122、130,完成进阶65
开发语言·c++·算法
j_xxx404_2 小时前
力扣--分治(快速排序)算法题I:颜色分类,排序数组
数据结构·c++·算法·leetcode·排序算法
阿Y加油吧2 小时前
力扣打卡day08——轮转数组、除自身外乘积
数据结构·算法·leetcode