栈的介绍和使用(算法)

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

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;

}

};

相关推荐
Proxy_ZZ015 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光15 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
小李子呢021115 小时前
前端八股6---v-model双向绑定
前端·javascript·算法
XH华15 小时前
数据结构第九章:树的学习(下)
数据结构·学习
2301_8227032016 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
cmpxr_16 小时前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台17 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab
会编程的土豆17 小时前
【数据结构与算法】再次全面了解LCS底层
开发语言·数据结构·c++·算法
大熊背18 小时前
如何利用Lv值实现三级降帧
算法·自动曝光·lv·isppipeline