CCF201803-1 跳一跳(序列處理)


試題編號: 201803-1
試題名稱:  跳一跳
時間限制: 1.0s
內存限制: 256.0MB
問題描述: 問題描述

  近來,跳一跳這款小游戲風靡全國,受到不少玩家的喜愛。
  簡化后的跳一跳規則如下:玩家每次從當前方塊跳到下一個方塊,如果沒有跳到下一個方塊上則游戲結束。
  如果跳到了方塊上,但沒有跳到方塊的中心則獲得1分;跳到方塊中心時,若上一次的得分為1分或這是本局游戲的第一次跳躍則此次得分為2分,否則此次得分比上一次得分多兩分(即連續跳到方塊中心時,總得分將+2,+4,+6,+8...)。
  現在給出一個人跳一跳的全過程,請你求出他本局游戲的得分(按照題目描述的規則)。

輸入格式

  輸入包含多個數字,用空格分隔,每個數字都是1,2,0之一,1表示此次跳躍跳到了方塊上但是沒有跳到中心,2表示此次跳躍跳到了方塊上並且跳到了方塊中心,0表示此次跳躍沒有跳到方塊上(此時游戲結束)。

輸出格式

  輸出一個整數,為本局游戲的得分(在本題的規則下)。

樣例輸入

1 1 2 2 2 1 1 2 2 0

樣例輸出

22

數據規模和約定

  對於所有評測用例,輸入的數字不超過30個,保證0正好出現一次且為最后一個數字。

 

 

 

 

問題分析

  一個簡單的序列處理問題。

  輸入到文件結束或最后一個數為0。

程序說明

  變量plus用於存儲加分。初值為0,連續得2分則每次增加2分,如果得1分(沒有跳到中心)則加分變為0分。

 

提交后得100分的C++語言程序如下:

 1 /* CCF201803-1 跳一跳 */
 2  
 3 #include <iostream>
 4  
 5 using namespace std;
 6  
 7 int main()
 8 {
 9     int a, sum = 0, plus = 0;
10     while(scanf("%d", &a) != EOF && a) {
11         sum += a;
12         if(a == 1)
13             plus = 0;
14         else if(a == 2) {
15             sum += plus;
16             plus += 2;
17         }
18     }
19     printf("%d\n", sum);
20  
21     return 0;
22 }
23  
View Code

 

  轉自 https://blog.csdn.net/tigerisland45/article/details/54755895


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM