传送门
惊叹考场dubuffdubuffdubuff。
这题还没有梭哈难啊233.
直接按照题意模拟就行了。
代码:
#include<bits/stdc++.h>
using namespace std;
int T,n,typ,dep[105];
bool f;
inline int calc(char s[]){
int len=strlen(s);
int ret=0,pos=0;
for(;pos!=len;++pos)if(isdigit(s[pos]))break;
while(isdigit(s[pos])&&pos!=len)ret=(ret<<3)+(ret<<1)+(s[pos]^48),++pos;
return ret;
}
int main(){
freopen("lx.in","r",stdin);
scanf("%d",&T);
while(T--){
stack<char>S;
set<char>exi;
char s[10];
int tot=0,now=0,ans=0;
memset(dep,0,sizeof(dep));
while(!S.empty())S.pop();
exi.clear(),scanf("%d%s",&n,&s),typ=0,f=1;
if(s[2]!='1'){
int len=strlen(s);
for(int i=4;i<len;++i){
if(!isdigit(s[i]))break;
typ=(typ<<3)+(typ<<1)+(s[i]^48);
}
}
int i=1;
for(;i<=n;++i,ans=max(ans,dep[now])){
scanf("%s",s);
if(s[0]=='E'){
if(!S.size()){f=0;break;}
exi.erase(S.top()),S.pop(),--now;
}
else{
scanf("%s",s);
char x[5],y[5];
scanf("%s%s",x,y);
if(exi.count(s[0])){f=0;break;}
S.push(s[0]),exi.insert(s[0]),++now;
if(dep[now-1]==-1){dep[now]=-1;continue;}
if(x[0]=='n'){
if(y[0]=='n'){dep[now]=dep[now-1];continue;};
dep[now]=-1;continue;
}
if(y[0]=='n'){dep[now]=dep[now-1]+1;continue;}
int X=calc(x),Y=calc(y);
if(X<=Y){dep[now]=dep[now-1];continue;}
else dep[now]=-1;
}
}
++i;
for(;i<=n;++i){
scanf("%s",s);
if(s[0]=='F')scanf("%s",s),scanf("%s",s),scanf("%s",s);
}
if(S.size())f=0;
if(f){
if(typ^ans)puts("No");
else puts("Yes");
}
else puts("ERR");
}
return 0;
}
2018.11.02 洛谷P3952 时间复杂度(模拟)的更多相关文章
-
洛谷 - P3952 - 时间复杂度 - 模拟
https://www.luogu.org/problemnew/show/P3952 这个模拟,注意每次进入循环的时候把新状态全部入栈,退出循环的时候就退栈. 第一次就错在发现ERR退出太及时,把剩 ...
-
2018.11.02 洛谷P2661 信息传递(拓扑排序+搜索)
传送门 按照题意模拟就行了. 先拓扑排序去掉不在环上面的点. 剩下的都是简单环了. 于是都dfsdfsdfs一遍求出最短的环就行. 代码: #include<bits/stdc++.h> ...
-
洛谷P3952 时间复杂度(模拟)
题意 题目链接 Sol 咕了一年的题解..就是个模拟吧 考场上写的递归也是醉了... 感觉一年自己进步了不少啊..面向数据编程的能力提高了不少 #include<bits/stdc++.h> ...
-
2018.11.02 洛谷P2831 愤怒的小鸟(状压dp)
传送门 状压一眼题. 直接f[i]f[i]f[i]表示未选择状态为iii时的最小次数. 然后考虑现在怎么转移. 显然可以直接枚举消掉某一个点或者某两个点,复杂度O(n22n)O(n^22^n)O(n2 ...
-
2018.11.02 洛谷P2312 解方程(数论)
传送门 直接做肯定会TLETLETLE. 于是考验乱搞能力的时候到了. 我们随便选几个质数来checkcheckcheck合法解,如果一个数无论怎么checkcheckcheck都是合法的那么就有很大 ...
-
洛谷 P3952 时间复杂度 解题报告
P3952 时间复杂度 题目描述 小明正在学习一种新的编程语言A++,刚学会循环语句的他激动地写了好多程序并 给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序, 于是你的机会 ...
-
计蒜客 时间复杂度 (模拟) &; 洛谷 P3952 时间复杂度
链接 : Here! 思路 : 这是一道大模拟, 区分好情况就没问题了 循环构成部分 : $F , x , i , j$ 和 $E$ , 需要注意的是 $i , j$, - 分析 $i, j$ 的情况 ...
-
洛谷P3952 时间复杂度【字符串】【模拟】
题目描述 小明正在学习一种新的编程语言 A++,刚学会循环语句的他激动地写了好多程序并 给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序, 于是你的机会来啦!下面请你编写程序 ...
-
洛谷 P3952 时间复杂度【模拟】
把No写成NO,WA了一发-- 现在看这题也不难-- 用一个栈,记一下前面F的字母,是否合法,合法的有多长,每次入栈弹栈即可 #include<iostream> #include< ...
随机推荐
-
ClassLoader相关内容
1.什么叫做bootstrap?作为形容词有依靠自己力量的:自己做的等意思,在我们计算机世界里,一般指的是自举,引导,引导程序. 那什么是bootstrapClassLoader呢?它是引导加载器,也 ...
-
coding 除了托管外,还能进行团队协作.
coding 除了托管外,还能进行团队协作. oschina 也是非常不错的.
-
Linux增加swap分区大小
1. 查看当前分区情况 free -m 2. 增加 swap 大小, 2G 左右 dd if=/dev/zero of=/var/swap bs=1024 count=2048000 3. 设置交换文 ...
-
pycharm+Django+MySQL项目连接数据库中原有数据库
1.安装驱动 一般会有MySQLdb.pymysql等,因为python版本等问题,我安装的是pymysql. 还可以在项目里安装,File->settings->project 2.在项 ...
-
Python的ctypes 和pyinstaller
这几天在学习python的爬虫, 无意中看到一篇博文 Python爬虫之自制英汉字典 发现里面的ctypes 和pyinstaller 还不了解,这边文章说白了就是你输入英文, python读取你的输 ...
-
Centos系统安装InfluxDB
概述安装influxDB时需要root用户或者管理员权限. 端口默认情况下,InfluxDB会使用如下的端口: * TCP8086端口是服务器监听端口,对HTTP API响应 * TCP8088端口是 ...
-
MySQL单行注释和多行释
单行注释:# 或者 -- 多行注释:/* ... */ 使用 # 时,# 和注释的内容之间可以没有空格 使用 -- 时,-- 和注释内容之间必须有空格
-
关于使用 IDEA Spring Boot 热部署
1,POM 中引用 <dependency> <groupId>org.springframework.boot</groupId> <artifactId& ...
-
ScrollView 定位
1.固定到顶部scroll_view.requestFocusFromTouch();scroll_view.setScrollX(0); 2.固定到指定位置 int[] location = new ...
-
在ant中将依赖jar包一并打包的方法
一般jar包里面是不包含jar文件的,如果自己的类有依赖其他jar包,可以通过ant命令将这些jar包解析,然后和自己的class文件打在一起,命令如下: build.xml 1 2 3 4 5 6 ...