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正好出現一次且爲最後一個數字。
|
代碼:ios
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 }