Description

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

跳一跳的游戏规则如下:

  • 玩家操控一个小棋子,在形状各异的“盒子”上边一路往前跳,当棋子跌落盒子之外时则游戏结束。
  • 盒子的正中心为“完美落点”,其他为“普通落点”。
  • 每次跳跃如果成功跳到了一个新的盒子上,记为“有效跳跃”,该落点为“有效落点”。
  • 每次有效跳跃结束时,如果存在上一次有效跳跃且距离上一次有效跳跃结束的时间不超过1秒,则本次有效跳跃记为“快速跳跃”。
  • 每次有效跳跃可以获得一定的分数。
    • 如果当前落点为完美落点,而且上一次有效落点存在且为完美落点,那么此次跳跃的得分为上次有效跳跃的得分+2。
    • 如果当前落点为完美落点,上一次有效落点存在且为普通落点,而且上次跳跃或者此次跳跃为快速跳跃,那么此次跳跃的得分为4分。
    • 如果当前落点为完美落点,上一次有效落点不存在或为普通落点,而且此次跳跃也不是快速跳跃,那么此次跳跃的得分为2分。
    • 如果当前落点为普通落点,而且此次跳跃是快速跳跃,那么此次跳跃的得分为2分。
    • 其他情况下,得分为1分。
  • 对于一些特殊的盒子,棋子在上面逗留1秒就可以获得额外的加分。
    • 魔方:额外得分为10分。
    • 便利店:额外得分为20分。
    • 音乐盒:额外得分为30分。
  • 如果某两次有效跳跃结束之间(或最后一次死亡跳跃结束和前一次有效跳跃结束之间,参见样例第5、6局游戏)的间隔不少于2秒,我们认为玩家在上一个盒子上逗留了1秒。

Input

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

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

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

“落点”为一个字符串,“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;
}


CSU - 2058 跳一跳的更多相关文章

  1. 挑战App Store,微信通过“跳一跳”秀了一下“小程序”的肌肉

    2017年即将结束的时候,微信放了一个大招.随着最新的微信v6.6.1版本更新,基于小程序的"小游戏"板块正式上线.微信上首发的这款"小游戏"叫"跳一 ...

  2. .NET开发一个微信跳一跳辅助程序

    昨天微信更新了,出现了一个小游戏"跳一跳",玩了一下 赶紧还蛮有意思的 但纯粹是拼手感的,玩了好久,终于搞了个135分拿了个第一名,没想到过一会就被朋友刷下去了,最高的也就200来 ...

  3. C#又能出来装个B了。一步一步微信跳一跳自动外挂

    PS:语言只是载体.思维逻辑才是王道 前天看见了个python的脚本.于是装python.配置环境变量.装pip.折腾了一上午,最终装逼失败. 于是进入博客园,顶部有篇文章吸引了我 .NET开发一个微 ...

  4. 用C#实现微信“跳一跳”小游戏的自动跳跃助手

    一.前言: 前段时间微信更新了新版本后,带来的一款H5小游戏“跳一跳”在各朋友圈里又火了起来,类似以前的“打飞机”游戏,这游戏玩法简单,但加上了积分排名功能后,却成了“装逼”的地方,于是很多人花钱花时 ...

  5. Adb+.net 实现微信跳一跳自动化

    第一次用adb,一开始只是想试试看能不能解析出,没有看网上的现有解析方式. 需要安卓机开启usb 调试+电脑运行.打开跳一跳的界面 点击程序 [开始]按钮即可开始,别的按钮都是调试用的 主要流程是用a ...

  6. 微信跳一跳Python

    微信最新的小程序里面出了个叫“跳一跳”的小游戏,大神们也通过Python实现了自动玩游戏具体代码 如下: Github地址: https://github.com/wangshub/wechat_ju ...

  7. 微信跳一跳辅助自动跳Python

    一.说明 此代码借鉴github一位大神所写,已经做了简化合并处理,如果能成功连上手机并运行,可以实现程序自动玩游戏,刷个1000+的分数轻轻松松 github源码地址 https://github. ...

  8. python如何玩“跳一跳”!(windows安桌版本请进!)

    最近"跳一跳",很火爆,有木有? 看了一下网上的教程,动作搭建了一下环境,就可以用脚本自动跑起来啦!!! 下面说一下android手机的实现过程: 首先,是python环境的搭建 ...

  9. 微信小程序跳一跳辅助程序(手动版)

    最近,微信官方推出了demo小程序游戏<跳一跳>,这个游戏操作简单,容易上手,却又不容易获得高分,受到很多人的喜爱(emm...这游戏有毒).自己也尝试了玩了几次,作为一个手残+脑残的资深 ...

随机推荐

  1. 20145234黄斐《Java程序设计》第七周

    教材学习内容总结 第十二章部分 - Lambda 认识Lambda语法 Lambda去可以重复,符合DRY原则,而且Lambda表达式可读性更好,操作更简单 匿名类型最大的问题就在于其冗余的语法,la ...

  2. html向js传递id

    html获取id方法: <div id="thediv1" style="display:block" onclick="ceshi(this. ...

  3. 【leetcode 简单】 第八十六题 有效的完全平方数

    给定一个正整数 num,编写一个函数,如果 num 是一个完全平方数,则返回 True,否则返回 False. 注意:不要使用任何内置的库函数,如  sqrt. 示例 1: 输入: 16 输出: Tr ...

  4. HDU 3449 Consumer (背包问题之有依赖背包)

    题目链接 Problem Description FJ is going to do some shopping, and before that, he needs some boxes to ca ...

  5. 矩阵 matrix

    传送门 注意这题时限是2s [问题描述] 有一个n × m的矩阵,你从左上角走到右下角,只能向下和向右走. 每个点上有一个重量v i,j 价值w i,j 的物品,你有一个容量为S的背包,经过一个点你可 ...

  6. 初涉sqlmap

    1.基本注入(这个工具kali或者bt下面有集成的,这里附加一个window免py版,提取码:3ldv) sqlmap -u http://url/xx.php?id=1  判断注入 sqlmap - ...

  7. TCP确认延时和Nagle算法

    TCP确认延时和Nagle算法 nagle 算法是   发送端 收到前一个报文的确认然后再发送下一个tcp数据.这样可以避免大量的小数据. TCP_NODELAY选项控制. Delay ACK是   ...

  8. WebRTC详解-zz

    1.WebRTC目的 WebRTC(Web Real-Time Communication)项目的最终目的主要是让Web开发者能够基于浏览器(Chrome\FireFox\...)轻易快捷开发出丰富的 ...

  9. thinkphp报错Call to undefined method app\index\controller\Index::fetch()

    因为要写一个系统,所以又重新下载了thinkphp,然后安装了一下.回忆起这个问题很容易让新手朋友费解.会出现如下报错:Call to undefined method app\index\contr ...

  10. Sort Colors I & II

    Given an array with n objects colored red, white or blue, sort them so that objects of the same colo ...