-
问题描述
试题编号: | 201803-1 |
试题名称: | 跳一跳 |
时间限制: | 1.0s |
内存限制: | 256.0MB |
问题描述: | 问题描述 近来,跳一跳这款小游戏风靡全国,受到不少玩家的喜爱。 输入格式 输入包含多个数字,用空格分隔,每个数字都是1,2,0之一,1表示此次跳跃跳到了方块上但是没有跳到中心,2表示此次跳跃跳到了方块上并且跳到了方块中心,0表示此次跳跃没有跳到方块上(此时游戏结束)。 输出格式 输出一个整数,为本局游戏的得分(在本题的规则下)。 样例输入 1 1 2 2 2 1 1 2 2 0 样例输出 22 数据规模和约定 对于所有评测用例,输入的数字不超过30个,保证0正好出现一次且为最后一个数字。 |
-
解决方案
#include<iostream>
using namespace std;
int main()
{int flag = 0, sum = 0, lastJump = 0, accumulateSum = 2;bool firstJump = true;while(scanf("%d", &flag)&&flag!=0){if(flag == 1){//跳到边上sum+=1;lastJump = 1;accumulateSum = 2;}else if(firstJump||lastJump == 1){//第一次跳到中心或上次跳到边上lastJump = 2;firstJump = false;sum += 2;}else{accumulateSum += 2;sum += accumulateSum;}}cout<<sum;
}
-
经验总结
作为ccf csp的第一题,题目并不难,但是仍然需要仔细分析题目描述的逻辑结构。最好在本子上画一下逻辑图。