nyoj_125盗梦空间

来源:互联网 发布:如何用为知笔记做批注 编辑:程序博客网 时间:2024/04/29 22:09

盗梦空间

《盗梦空间》是一部精彩的影片,在这部电影里,Cobb等人可以进入梦境之中,梦境里的时间会比现实中的时间过得快得多,这里假设现实中的3分钟,在梦里就是1小时。

然而,Cobb他们利用强效镇静剂,可以从第一层梦境进入第二层梦境,甚至进入三层,四层梦境,每层梦境都会产生同样的时间加速效果。那么现在给你Cobb在各层梦境中经历的时间,你能算出现实世界过了多长时间吗?

比如,Cobb先在第一层梦境待了1个小时,又在第二层梦境里待了1天,之后,返回第一层梦境之后立刻返回了现实。

那么在现实世界里,其实过了396秒(6.6分钟)

输入
第一行输入一个整数T(0<=T<=100),表示测试数据的组数。
每组测试数据的第一行是一个数字M(3<=M<=100)
随后的M行每行的开头是一个字符串,该字符串如果是"IN" 则Cobb向更深层的梦境出发了,如果是字符串"OUT"则表示Cobb从深层的梦回到了上一层。如果是首字符串是"STAY"则表示Cobb在该层梦境中停留了一段时间,本行随后将是一个整数S表示在该层停留了S分钟(1<=S<=10000000)。数据保证在现实世界中,时间过了整数秒。
输出
对于每组测试数据,输出现实世界过的时间(以秒为单位)。
样例输入
16INSTAY 60INSTAY 1440OUTOUT
样例输出
396
代码:
#include<stdio.h>#include<string.h>#include<math.h>int main(){ int n,x,y,m; double sum; char s[6]; scanf("%d",&y); while(y--) {  scanf("%d",&m);  x=0;sum=0.0;  while(m--){        scanf("%s",s);       if(strcmp("IN",s)==0)          x++;                              if(strcmp("STAY",s)==0){         scanf("%d",&n);                                   sum+=((n*1.0)/pow(20.0,x))*60;               }                                               if(strcmp("OUT",s)==0)x--;           }        printf("%d\n",int(sum)); }  return 0;}
思路解析:
刚开始做这道题没有思路,搁置了一天。现在仔细想了想,原来是这么回事,难道是我没有看这部电影的原因,呵呵,有时间一定感受一下。言归正传。。。
判断三种情况即可。
x表示进的层数,
当输入的字符串为"IN"时,进梦境,x++;
当输入的字符串为"STAY"时,输入n,表示在这一层梦境待了n秒钟,因为梦境与现实的时间比例为pow(20.0,x),故可求此时,现实的时间即sum;
当输入的字符串为"OUT"时,出梦境,x--;
最后,sum转化为int型输出。
有思路才有出路啊!!!
收获:
strcmp()函数:
原型:extern int strcmp(const char *s1,const char * s2);
所在头文件:string.h
功能:比较字符串s1和s2。
一般形式:strcmp(字符串1,字符串2)
当s1<s2时,返回为负数 注意不是-1
当s1==s2时,返回值= 0
当s1>s2时,返回正数 注意不是1
即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇'\0'为止。如:
"A"<"B" "a">"A" "computer">"compare"
特别注意:strcmp(const char *s1,const char * s2)这里面只能比较字符串,不能比较数字等其他形式的参数。
pow()函数:
头文件:math.h/cmath(C++中)
功能:计算x的y次
返回值:x不能为负数且y为小数,或者x为0且y小于等于0,返回幂指数的结果。
返回类型:double型,int,float会给与警告!


0 0
原创粉丝点击