1 Star 0 Fork 1

saigon/Algorithms

forked from charlieshu/Algorithms 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
前缀和.cpp 1.08 KB
一键复制 编辑 原始数据 按行查看 历史
charlie 提交于 2024-01-09 00:01 . move from github to gitee
#include <iostream>
#include <stack>
#include <cstring>
#define MAXN 1000
using namespace std;
struct mem{
bool nc;
int num;
char cac;
};
int main(){
stack<mem> sta;
mem now;
char s;
for(int i=0;true;i++){
cin>>s;
// cout<<i<<" "<<sta.size()<<endl;
if(s == ';'){
// cout<<114514;
while(sta.size() != 0 && now.nc && sta.top().nc){
mem bef=sta.top();
sta.pop();
if(sta.top().cac == '+'){
now.num += bef.num;
}
else if(sta.top().cac == '-'){
now.num = bef.num-now.num;
}
else if(sta.top().cac == '*'){
now.num *= bef.num;
}
else if(sta.top().cac == '/'){
now.num = bef.num/now.num;
}
// cout<<now.num<<endl;
sta.pop();
}
if(sta.size() == 0 && now.nc)
break;
sta.push(now);
now.nc = true;
now.num = 0;
}
else if(s <= '9' && s >= '0'){
now.num = now.num*10+(s-'0');
}
else{
if(s == '+' || s == '-' || s == '*' || s == '/'){
now.nc = false;
now.cac = s;
}
}
}
// cout<<s<<endl;
cout<<now.num;
return 0;
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/saigonshu/algorithm.git
git@gitee.com:saigonshu/algorithm.git
saigonshu
algorithm
Algorithms
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385