ACM-ICPC 2018 沈阳赛区网络预赛 B Call of Accepted(表达式求值)
题目链接:https://nanti.jisuanke.com/t/31443
相关前置链接
https://www.cnblogs.com/dolphin0520/p/3708602.html
https://zh.wikipedia.org/wiki/调度场算法
https://zh.wikipedia.org/wiki/逆波兰表示法
https://blog.csdn.net/f_zyj/article/details/51509958
思路
- 调度场算法+后缀表达式(逆波兰)求值
- 先将中缀表达式化成后缀表达式(调度场)
- 在对后缀表达式求值
- 前缀和处理优先级+递归构造表达式树
- 括号内的元素优先级较高,因此处理出来每个位置的前缀和越大的优先级越高
- 构造表达式树本质:优先级越高越早计算,意味着越靠近递归返回边界,意味着在递归树越深的位置
- 因此会出现十分有趣的遍历顺序,+,-,*,/,d
- 加上-和/和d是不满足交换律的,就是前面的符号要先计算,所以倒着扫
#include<bits/stdc++.h>
#define se second
#define ft first
#define pii pair<int,int>
#define mk make_pair
using namespace std;
char s[105],f[105];
int i,n;
pii ans;
pii add(pii x,pii y){
return mk(x.ft+y.ft,x.se+y.se);
}
pii del(pii x,pii y){
return mk(x.ft-y.se,x.se-y.ft);
}
pii mul(pii x,pii y){
int a=min(x.ft*y.ft,x.ft*y.se),b=max(x.ft*y.ft,x.ft*y.se);
a=min(a,x.se*y.ft);b=max(b,x.se*y.ft);
a=min(a,x.se*y.se);b=max(b,x.se*y.se);
return mk(a,b);
}
pii D(pii x,pii y){
return mk(x.ft,x.se*y.se);
}
pii dfs(int l,int r){
int i;
for(i=l;i<=r;i++){
if(s[i]=='+'&&f[i]==f[l])
return add(dfs(l,i-1),dfs(i+1,r));
}
for(i=r;i>=l;i--){
if(s[i]=='-'&&f[i]==f[l])return del(dfs(l,i-1),dfs(i+1,r));
}
for(i=l;i<=r;i++){
if(s[i]=='*'&&f[i]==f[l])return mul(dfs(l,i-1),dfs(i+1,r));
}
for(i=r;i>=l;i--){
if(s[i]=='d'&&f[i]==f[l])return D(dfs(l,i-1),dfs(i+1,r));
}
if(s[l]=='('){
for(i=l+1;f[i]>=f[l+1];i++);
return dfs(l+1,i-1);
}
int tp=0;
for(i=l;i<=r;i++){
if(s[i]<'0'||s[i]>'9')break;
tp*=10;
tp+=s[i]-'0';
}
return mk(tp,tp);
}
int main(){
while(~scanf("%s",s)){
memset(f,0,sizeof(f));
n=strlen(s);
f[0]=1;
for(i=1;i<n;i++){
if(s[i-1]=='(')f[i]=f[i-1]+1;
else if(s[i]==')')f[i]=f[i-1]-1;
else f[i]=f[i-1];
}
ans=dfs(0,n-1);
printf("%d %d\n",ans.ft,ans.se);
}
}
ACM-ICPC 2018 沈阳赛区网络预赛 B Call of Accepted(表达式求值)的更多相关文章
- ACM-ICPC 2018 沈阳赛区网络预赛 B Call of Accepted(表达式求值)
https://nanti.jisuanke.com/t/31443 题意 给出一个表达式,求最小值和最大值. 表达式中的运算符只有'+'.'-'.'*'.'d',xdy 表示一个 y 面的骰子 ro ...
- ACM-ICPC 2018 沈阳赛区网络预赛 K Supreme Number(规律)
https://nanti.jisuanke.com/t/31452 题意 给出一个n (2 ≤ N ≤ 10100 ),找到最接近且小于n的一个数,这个数需要满足每位上的数字构成的集合的每个非空子集 ...
- ACM-ICPC 2018 沈阳赛区网络预赛-K:Supreme Number
Supreme Number A prime number (or a prime) is a natural number greater than 11 that cannot be formed ...
- ACM-ICPC 2018 沈阳赛区网络预赛-D:Made In Heaven(K短路+A*模板)
Made In Heaven One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. ...
- 图上两点之间的第k最短路径的长度 ACM-ICPC 2018 沈阳赛区网络预赛 D. Made In Heaven
131072K One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. Howe ...
- ACM-ICPC 2018 沈阳赛区网络预赛 J树分块
J. Ka Chang Given a rooted tree ( the root is node 11 ) of NN nodes. Initially, each node has zero p ...
- ACM-ICPC 2018 沈阳赛区网络预赛 K. Supreme Number
A prime number (or a prime) is a natural number greater than 11 that cannot be formed by multiplying ...
- ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph
"Oh, There is a bipartite graph.""Make it Fantastic." X wants to check whether a ...
- Fantastic Graph 2018 沈阳赛区网络预赛 F题
题意: 二分图 有k条边,我们去选择其中的几条 每选中一条那么此条边的u 和 v的度数就+1,最后使得所有点的度数都在[l, r]这个区间内 , 这就相当于 边流入1,流出1,最后使流量平衡 解析: ...
随机推荐
- SQLServer BI 学习笔记
MSBI 学习库: https://ask.hellobi.com/blog/biwork SSAS库部署的几种方式 http://www.cnblogs.com/aspnetx/archive/20 ...
- 844. Backspace String Compare判断删除后的结果是否相等
[抄题]: Given two strings S and T, return if they are equal when both are typed into empty text editor ...
- 使用GitHub管理代码
第一步:注册GitHub账户. 第二步:下载GitHub desktop. 第三步:打开软件界面之后请使用鼠标点击左上角的“file”选项按钮,选择添加本地文件. 第四步:导入文件 第五步:在左下角大 ...
- 关于vue的npm run dev和npm run build
├─build │ ├─build.js │ ├─check-versions.js │ ├─dev-client.js │ ├─dev-server.js │ ├─utils.js │ ├─vue- ...
- solr简介、学习详细过程!(超详细~)
solr是什么呢? 一.Solr它是一种开放源码的.基于 Lucene Java 的搜索服务器,易于加入到 Web 应用程序中. 二.Solr 提供了层面搜索(就是统计).命中醒目显示并且支持多种输出 ...
- 视觉slam十四讲
对这个的学习一直都在,感觉到了这本书很强大呀!!! ch2---安装ubuntu:安装kdevelop. ch3---安装eigen3---几何模块:安装Pangolin可视化. ch4---安装So ...
- 当前的开源SLAM方案
开源方案 传感器形式 地址链接 MonoSLAM 单目 https://github.com/hanmekim/SceneLib2 PTAM 单目 http://www.robots.ox.ac. ...
- JFinal Web开发学习(八)后台集成H-ui-admin前端框架
h-ui-admin是一个很不错的前端框架h-ui实现的一个后台管理系统的前端. 1.在WebRoot目录下新建admin目录 2.下载h-ui-admin(当前最新是2.5版本)并解压至admin文 ...
- 关于EOF:
请先看下面一段程序: #include"stdio.h" int main() { ],t; int i,j; while(scanf("%s",a)!=EOF ...
- springMvc入门--初识springMvc
springMvc是什么 springmvc是表现层的框架,是一个spring的表现层组件.是整个spring框架的一部分,但是也可以不使用springmvc.跟struts2框架功能类似.其中的mv ...