题目链接: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(表达式求值)的更多相关文章

  1. ACM-ICPC 2018 沈阳赛区网络预赛 B Call of Accepted(表达式求值)

    https://nanti.jisuanke.com/t/31443 题意 给出一个表达式,求最小值和最大值. 表达式中的运算符只有'+'.'-'.'*'.'d',xdy 表示一个 y 面的骰子 ro ...

  2. ACM-ICPC 2018 沈阳赛区网络预赛 K Supreme Number(规律)

    https://nanti.jisuanke.com/t/31452 题意 给出一个n (2 ≤ N ≤ 10100 ),找到最接近且小于n的一个数,这个数需要满足每位上的数字构成的集合的每个非空子集 ...

  3. 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 ...

  4. 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. ...

  5. 图上两点之间的第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 ...

  6. 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 ...

  7. 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 ...

  8. ACM-ICPC 2018 沈阳赛区网络预赛 F. Fantastic Graph

    "Oh, There is a bipartite graph.""Make it Fantastic." X wants to check whether a ...

  9. Fantastic Graph 2018 沈阳赛区网络预赛 F题

    题意: 二分图 有k条边,我们去选择其中的几条 每选中一条那么此条边的u 和 v的度数就+1,最后使得所有点的度数都在[l, r]这个区间内 , 这就相当于 边流入1,流出1,最后使流量平衡 解析: ...

随机推荐

  1. Javascript 强制浏览器渲染Dom文档

    在Cordova+Framework7开发Hybrid App时,在iPhone 7上遇到一个诡异的现象(Chrome浏览器.Android都正常):js修改手风琴中的input文本框的值后,但页面仍 ...

  2. 【js语法】array

    array操作说明 链接:http://www.w3school.com.cn/jsref/jsref_obj_array.asp 函数说明: concat():把两个array连接起来 join() ...

  3. day 16 包,random,shutil

    包: 函数过多,可以分模块文件去管理函数,模块文件过多,将模块文件分类放在一个个的文件夹中,这个文件夹就叫做包,组织结构更加清晰,合理! 模式就是被别人使用,包既然是一些模块的集合,也是被调用. 文件 ...

  4. webpack(一) 安装使用

    (一)webpack的安装 webpack是基于node.js,因此需要安装node.js. 安装好node.js 后,全局安装webpack,命令如下 npm install webpack -g ...

  5. linux命令学习之:passwd

    passwd命令用于设置用户的认证信息,包括用户密码.密码过期时间等.系统管理者则能用它管理系统用户的密码.只有管理者可以指定用户名称,一般用户只能变更自己的密码. 语法 passwd(选项)(参数) ...

  6. Mysql在Linux的基本操作文档

    总结了Mysql在Linux下的应用,以下是Linux操作系统操作MySQL常用命令小结,需要的朋友参考下: 1.Mysql服务 # chkconfig --list 列出所有系统服务 # chkco ...

  7. Android:webView加载h5网页视频,播放不了,以及横屏全屏的问题和实现自定义加载进度条的效果

    1.webView加载h5网页视频,播放不了,android3.0之后要在menifest添加硬件加速的属性 android:hardwareAccelerated="true". ...

  8. Python数据分析--Pandas知识点(一)

    本文主要是总结学习pandas过程中用到的函数和方法, 在此记录, 防止遗忘 1. 重复值的处理 利用drop_duplicates()函数删除数据表中重复多余的记录, 比如删除重复多余的ID. im ...

  9. Cloud Foundry v2 部署及入门运维

    之前写过一个Guide for Cloud Foundry New Teamer.不过似乎已经有些过时,那会实验室主要是针对的CF v1进行的研究,现在已经全面进入V2时代了.所以更新一下关于Clou ...

  10. Git 安装和使用教程(更加详细)

    转载至:https://www.cnblogs.com/smuxiaolei/p/7484678.html#undefined Git 安装和使用教程 git 提交 全部文件 git add .  g ...