Description

冰弦非常热衷于过气微信小游戏“跳一跳”,现在给出了他每次游戏时的一些信息,请你帮他计算一下每局游戏的得分。

跳一跳的游戏规则如下:

Input

输入包含不超过10组数据,每组数据描述了冰弦的一局游戏。

每组数据有若干行,除最后一行外,每一行描述一次有效跳跃(总有效跳跃数不超过10),格式为“跳跃结束的时间 落点 盒子类型”;最后一行是“跳跃结束的时间 GAME OVER”,表示小棋子跌落盒子之外,游戏结束。

“跳跃结束的时间”为一个不超过10的整数,单位为毫秒。

“落点”为一个字符串,“Perfect”表示完美落点,“Good”表示普通落点。

“盒子类型”为一个字符串,“Rubik”表示魔方,“Store”表示便利店,“Music”表示音乐盒,“Box”表示普通盒子。

保证数据合法地描述了一局正常有效的游戏。

更多输入格式的信息请参考样例输入。

Output

对于每组数据,输出一行一个整数,表示冰弦在此局游戏中获得的分数。

Sample Input

1000 Good Box
3000 Good Box
5000 Good Box
7000 GAME OVER
1000 Good Box
2000 Good Box
3000 Good Box
4000 GAME OVER
1000 Perfect Box
2000 Perfect Box
3000 Perfect Box
4000 GAME OVER
1000 Perfect Rubik
2000 Perfect Store
4000 Perfect Music
8000 Perfect Box
16000 GAME OVER
4000 Perfect Rubik
5000 Perfect Rubik
9000 GAME OVER
4000 Perfect Rubik
8000 Perfect Rubik
16000 GAME OVER

Sample Output

3
5
12
70
16
26

Hint

对于第一局游戏,得分为 1+1+1=3 ;
对于第二局游戏,得分为 1+2+2=5 ;
对于第三局游戏,得分为 2+4+6=12 ;
对于第四局游戏,得分为 2+4+20+6+30+8=70 。

冰弦不会手抖进行“无效跳跃”的,不用纠结“无效跳跃”的问题。

Source

Author

devenber


#include<cstdio>
#include<iostream>
#include<string>
using namespace std;
long long tim,tim_last;
long long flag,flag1,flag2,num,cnt;
string s1, s2,s11,s22;
string c1 = "Good", c2 = "Perfect", c3 = "GAME";
string a1 = "Rubik", a2 = "Store", a3 = "Music";
int main()
{
int cas = 0;
flag=flag1=flag2 = 0; num = 0; cnt = 0; tim_last = 0;
while ((cin >> tim >> s1 >> s2)&&(cas)<=10)
{
if (flag && (tim - tim_last) <= 1000)
flag1 = 1;
else
flag1 = 0;
if ((tim - tim_last) >= 2000)
{
if (s22 == a1)
num += 10;
else if (s22 == a2)
num += 20;
else if (s22 == a3)
num += 30;
}
if (s1 == c2)
{
if (flag == 2){
flag = 2;
cnt += 2; num += cnt;
}
else if (flag == 1 && (flag1 || flag2)){
flag = 2;
cnt = 4; num += cnt;
}
else if ((flag == 0 || flag == 1) && flag1 == 0) {
flag = 2;
cnt = 2; num += cnt;
}
else{
flag = 2;
cnt = 1; num += cnt;
}
}
else if (s1 == c1)
{
if (flag1 == 1)
{
flag = 1;
cnt = 2; num += cnt;
}
else
{
flag = 1;
cnt = 1;
num += cnt;
}
}
else if (s1 == c3)
{
printf("%lld\n", num);
cas++;
tim_last = 0;
flag2 = 0;
flag = 0; flag1 = 0; cnt = 0; num = 0;
s11 = "0"; s22 = "0";
continue;
}
tim_last = tim;
flag2 = flag1;
s11 = s1, s22 = s2;
}
return 0;
}


05-08 15:27