[NOIp2017] luogu P3952 时间复杂度
跪着看评测很优秀。
题目描述
给你若干个程序,这些程序只有 For 循环,求这些程序的时间复杂度。
Solution
大模拟。讲下细节。
flag[i]flag[i]flag[i] 表示第 iii 位有没有对复杂度产生贡献,而且只有 F 开头的语句才会计算。
ed[i]ed[i]ed[i] 表示第 iii 位配套的 E 的位置(第 iii 位必须是 F)。
注意判 CE 的时候,
F x 2 1
F x 1 2
E
E
这个程序也要判 CE。
最后贴上代码
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define max(x,y) ((x)>(y)?(x):(y))
#define ERR() {puts("ERR");return;}
int T;
int L,c;
char R[20];
int ans=0,now,h,cnt,cur;
char str[110][20];
int flag[110];
int x,y;
int st[110],ed[110];
bool bk[130];
int get(char*s,int t){
int l=strlen(s);
for(int i=0;i<l;++i){
if(s[i]==' ') --t;
if(!t){
if(s[i+1]=='n') return 101;
now=i;cnt=0;
do{
++now;
cnt=cnt*10+s[now]-'0';
}while(s[now+1]>='0'&&s[now+1]<='9');
return cnt;
}
}
}
int count(int l,int r){
if(ed[l]==r){
if(flag[l]==1) return count(l+1,r-1)+1;
else if(!flag[l]) return count(l+1,r-1);
return 0;
}
int sum=0;
for(int i=l;i<=r;i=ed[i]+1)
sum=max(sum,count(i,ed[i]));
return sum;
}
void work(){
ans=0;
if(R[3]=='1') ans=0;
else{
now=4;
do{
++now;
ans=ans*10+R[now]-'0';
}while(R[now+1]>='0'&&R[now+1]<='9');
}
for(int i=1;i<=L;++i){
x=get(str[i],2);y=get(str[i],3);
if(y==101&&x!=101&&str[i][0]=='F') flag[i]=1;
else if(x>y) flag[i]=-1;
else flag[i]=0;
}
memset(bk,0,sizeof(bk));
memset(st,0,sizeof(st));h=0;
memset(ed,0,sizeof(ed));
for(int i=1;i<=L;++i){
if(str[i][0]=='F'){
++h;
if(bk[str[i][2]]) {ERR();}
else bk[str[i][2]]=1;
st[h]=i;
}
else{
ed[st[h]]=i;
bk[str[st[h]][2]]=0;
--h;
}
if(h<0) ERR() ;
}
if(h) ERR();
puts((count(1,L)==ans)?"Yes":"No");
}
int main(){
scanf("%d",&T);
while(T--){
scanf("%d%s",&L,R+1);
getchar();
for(int i=1;i<=L;++i)
gets(str[i]);
work();
}
}
[NOIp2017] luogu P3952 时间复杂度的更多相关文章
- luogu P3952 时间复杂度 模拟
题目链接 luogu P3952 时间复杂度 题解 直接模拟即可 注意不要直接return 我真是naive ...... 代码 #include<map> #include<sta ...
- 【luogu P3952 时间复杂度】 题解
对于2017 D1 T2 这道题 实实在在是个码力题,非常考验耐心. 其实大体的思路并不是非常难想出来,但是要注意的小细节比较多. 题目链接:https://www.luogu.org/problem ...
- [LUOGU] P3952 时间复杂度
其实,也没那么难写 这种模拟题,仔细分析一下输入格式,分析可能的情况,把思路写在纸上,逐步求精,注意代码实现 主要思路就是算一个时间复杂度,和给出的复杂度比较,这就先设计一个函数把给出的复杂度由字符串 ...
- P3952 时间复杂度
P3952 时间复杂度 题目描述 小明正在学习一种新的编程语言 A++,刚学会循环语句的他激动地写了好多程序并 给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序, 于是你的机 ...
- 洛谷 P3952 时间复杂度 解题报告
P3952 时间复杂度 题目描述 小明正在学习一种新的编程语言A++,刚学会循环语句的他激动地写了好多程序并 给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序, 于是你的机会 ...
- 洛谷 - P3952 - 时间复杂度 - 模拟
https://www.luogu.org/problemnew/show/P3952 这个模拟,注意每次进入循环的时候把新状态全部入栈,退出循环的时候就退栈. 第一次就错在发现ERR退出太及时,把剩 ...
- 洛谷P3952 时间复杂度【字符串】【模拟】
题目描述 小明正在学习一种新的编程语言 A++,刚学会循环语句的他激动地写了好多程序并 给出了他自己算出的时间复杂度,可他的编程老师实在不想一个一个检查小明的程序, 于是你的机会来啦!下面请你编写程序 ...
- LOJ P3952 时间复杂度 noip 暴力 模拟
https://www.luogu.org/problemnew/show/P3952 模拟,日常认识到自己zz. #include<iostream> #include<cstdi ...
- luogu 3952 时间复杂度
noip2017 D1T2 时间复杂度 某zz选手考场上写了1.5h 考完之后发现自己写的是错的 但是结果A了??? 题目大意: 一种新的编程语言 A++ 给出一个程序只有循环语句 并给出这个程序的时 ...
随机推荐
- java获取电脑mac物理地址
import java.net.InetAddress;import java.net.NetworkInterface;import java.net.SocketException;import ...
- 自定义 behavior - 完美仿 QQ 浏览器首页,美团商家详情页
使用CoordinatorLayout打造各种炫酷的效果 自定义Behavior -- 仿知乎,FloatActionButton隐藏与展示 NestedScrolling 机制深入解析 一步步带你读 ...
- Linux、Windows 和 Mac 中的换行符对比
原文地址:Linux.Windows 和 Mac 中的换行符对比 博客地址:http://www.moonxy.com 一.前言 经常使用 Window.Linux 等不同操作系统的开发者,在处理文本 ...
- Linux 中 Xampp 的 https 安全证书配置
博客地址:http://www.moonxy.com 一.前言 HTTP 协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的 HTTP 的 ...
- 《Java7并发编程实战手册》读书笔记
一.线程管理 1.线程的创建和运行 创建线程的2种方式: 继承Thread类,并覆盖run()方法 创建一个实现Runnable接口的类.使用带参数的Thread构造器来创建Thread对象 每个Ja ...
- mysql创建表时字段类型选择与优化
一.选择原则 1.应该尽量使用可以正确存储数据的最小字段类型 2.选用简单的数据类型,例如:一个是尽量用mysql内置的字段类型来存储日期和时间:另一个存储IP地址尽量用整型:能用整型的尽量不用字符串 ...
- 转:int整数除以int整数一定得到的是int整数(易忽视)
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/u014053368/article/de ...
- windows环境下搭建python虚拟环境及离线移植
以python3.6为例 ①安装virtualenv: #pip安装之后在D:\Python36\Scripts目录下可以看到多了一个virtualenv.exe可执行文件pip install vi ...
- [python]兔子问题,斐波那契数列 递归&非递归
假设一对幼年兔子需要一个月长成成年兔子,一对成年兔子一个月后每个月都可以繁衍出一对新的幼年兔子(即兔子诞生两个月后开始繁殖).不考虑死亡的情况,问第 N 个月时共有多少对兔子? 结果前几个月的兔子数量 ...
- 词向量(one-hot/SVD/NNLM/Word2Vec/GloVe)
目录 词向量简介 1. 基于one-hot编码的词向量方法 2. 统计语言模型 3. 从分布式表征到SVD分解 3.1 分布式表征(Distribution) 3.2 奇异值分解(SVD) 3.3 基 ...