CSU - 2058 跳一跳
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 跳一跳的更多相关文章
- 挑战App Store,微信通过“跳一跳”秀了一下“小程序”的肌肉
2017年即将结束的时候,微信放了一个大招.随着最新的微信v6.6.1版本更新,基于小程序的"小游戏"板块正式上线.微信上首发的这款"小游戏"叫"跳一 ...
- .NET开发一个微信跳一跳辅助程序
昨天微信更新了,出现了一个小游戏"跳一跳",玩了一下 赶紧还蛮有意思的 但纯粹是拼手感的,玩了好久,终于搞了个135分拿了个第一名,没想到过一会就被朋友刷下去了,最高的也就200来 ...
- C#又能出来装个B了。一步一步微信跳一跳自动外挂
PS:语言只是载体.思维逻辑才是王道 前天看见了个python的脚本.于是装python.配置环境变量.装pip.折腾了一上午,最终装逼失败. 于是进入博客园,顶部有篇文章吸引了我 .NET开发一个微 ...
- 用C#实现微信“跳一跳”小游戏的自动跳跃助手
一.前言: 前段时间微信更新了新版本后,带来的一款H5小游戏“跳一跳”在各朋友圈里又火了起来,类似以前的“打飞机”游戏,这游戏玩法简单,但加上了积分排名功能后,却成了“装逼”的地方,于是很多人花钱花时 ...
- Adb+.net 实现微信跳一跳自动化
第一次用adb,一开始只是想试试看能不能解析出,没有看网上的现有解析方式. 需要安卓机开启usb 调试+电脑运行.打开跳一跳的界面 点击程序 [开始]按钮即可开始,别的按钮都是调试用的 主要流程是用a ...
- 微信跳一跳Python
微信最新的小程序里面出了个叫“跳一跳”的小游戏,大神们也通过Python实现了自动玩游戏具体代码 如下: Github地址: https://github.com/wangshub/wechat_ju ...
- 微信跳一跳辅助自动跳Python
一.说明 此代码借鉴github一位大神所写,已经做了简化合并处理,如果能成功连上手机并运行,可以实现程序自动玩游戏,刷个1000+的分数轻轻松松 github源码地址 https://github. ...
- python如何玩“跳一跳”!(windows安桌版本请进!)
最近"跳一跳",很火爆,有木有? 看了一下网上的教程,动作搭建了一下环境,就可以用脚本自动跑起来啦!!! 下面说一下android手机的实现过程: 首先,是python环境的搭建 ...
- 微信小程序跳一跳辅助程序(手动版)
最近,微信官方推出了demo小程序游戏<跳一跳>,这个游戏操作简单,容易上手,却又不容易获得高分,受到很多人的喜爱(emm...这游戏有毒).自己也尝试了玩了几次,作为一个手残+脑残的资深 ...
随机推荐
- 让PHPCms内容页支持JavaScript的修改方法
在文件..\caches\caches_model\caches_data\content_input.class.php中找到函数: function get($data,$isimport = 0 ...
- 【leetcode 简单】 第五十九题 同构字符串
给定两个字符串 s 和 t,判断它们是否是同构的. 如果 s 中的字符可以被替换得到 t ,那么这两个字符串是同构的. 所有出现的字符都必须用另一个字符替换,同时保留字符的顺序.两个字符不能映射到同一 ...
- SolrJ查询条件组合查询实现——(十六)
带查询条件的实现原理: 查询按钮被包在一个大表单,表单还有三个隐藏域,一个商品筛选,一个 价格,一个排序,每次点击查询时候清空三个隐藏域,就带着一个大条件去查询;点击下面的筛选条件时,给隐藏域的筛选条 ...
- jQuery Validate自定义金钱验证,是否为金额格式,保留两位小数,并支持千分制货币格式
//自定义函数实现 isMoney: function (value, element){ // return this.optional(element) || /(^[1-9]([0-9]+)?( ...
- java 添加一组元素
在java包中的Arrays和Collection类中都有很多实用方法,可以在一个Collection中添加一组元素,Array.asList()方法接受一个数组或是一个用逗号分隔的元素列表(使用可变 ...
- Luogu P2069 【松鼠吃果子】
推荐一波数组模拟链表的讲解 这道题呢,数组写的话不好删除(因为后面要接过来),自然想到链表 对于一个果子,我们可以维护其前驱和后继,我们不妨记与一个点相邻的上面的点为其前驱,下面的点为其后继 观察到题 ...
- MySQL学习笔记:删除存储过程和函数
删除存储过程.存储函数主要使用drop语句: drop procedure —— 删除存储过程 drop function —— 删除存储函数 语法: DROP {PROCEDURE|FUNCTI ...
- KnockoutJs学习笔记(二)
这篇文章主要用于记录学习Working with observable arrays的测试和体会. Observable主要用于单一个体的修改订阅,当我们在处理一堆个体时,当UI需要重复显示一些样式相 ...
- spring-boot分环境打包为jar包
1.pom配置 <!-- 多环境打包 start --> <profiles> <!-- 开发环境配置 --> <profile> <id> ...
- Iterator 迭代器
意图 提供一种方法顺序访问一个聚合对象中各个元素 , 而又不需暴露该对象的内部表示. 动机 一个聚合对象, 如列表(list), 应该提供一种方法来让别人可以访问它的元素,而又不需暴露它的内部结构 迭 ...