CCF CSP認證考試試題


1. 201803-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正好出現一次且為最后一個數字。

代碼:

 1 #include<iostream>
 2 #include<vector>
 3 #include<numeric>
 4 using namespace std;
 5 
 6 int score(vector<int> &vec)
 7 {
 8     vector<int> nums(vec.size());
 9     for (int i = 0; i < vec.size(); ++i)
10     {
11         if (i == 0 && vec[0] == 2)
12             nums[i] = 2;
13         else if (i == 0 && vec[0] == 1)
14             nums[i] = 1;
15         else if (vec[i] == 2 && nums[i - 1] == 1)
16             nums[i] = 2;
17         else if (vec[i] == 2 && nums[i - 1] != 1)
18             nums[i] = nums[i - 1] + 2;
19         else if (vec[i] == 1)
20             nums[i] = 1;
21     }
22     int sum = accumulate(nums.begin(), nums.end(), 0);
23     return sum;
24 }
25 
26 int main()
27 {
28     vector<int> vec;
29     int word;
30     while (cin >> word && word != 0)
31         vec.push_back(word);
32     cout << score(vec) << endl;
33     return 0;
34 }

 


免責聲明!

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



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