HDU Computer Transformation1041 題解

來源:互聯網
上載者:User

標籤:des   style   blog   color   io   os   ar   for   sp   

Problem DescriptionA sequence consisting of one digit, the number 1 is initially written into a computer. At each successive time step, the computer simultaneously tranforms each digit 0 into the sequence 1 0 and each digit 1 into the sequence 0 1. So, after the first time step, the sequence 0 1 is obtained; after the second, the sequence 1 0 0 1, after the third, the sequence 0 1 1 0 1 0 0 1 and so on. 

How many pairs of consequitive zeroes will appear in the sequence after n steps? 
 
InputEvery input line contains one natural number n (0 < n ≤1000). 
OutputFor each input n print the number of consecutive zeroes pairs that will appear in the sequence after n steps.
 
Sample Input
23
 
Sample Output
11

找規律的問題,分開0和1的衍生問題就好理解了。

#include <stdio.h>#include <vector>#include <string.h>#include <algorithm>#include <iostream>#include <string>#include <limits.h>#include <stack>#include <queue>#include <set>#include <map>using namespace std;const short MAX_N = 1001;vector<short> tbl0[MAX_N], tbl1[MAX_N];//inverse saved numbersvoid addLargeNum(vector<short> &rs, vector<short> &a, vector<short> &b){int n = (int)a.size(), m = (int)b.size();rs.clear();short carry = 0;for (int i = 0, j = 0; i < n || j < m || carry; i++, j++){short an = i < n ? a[i] : 0;short bn = j < m ? b[i] : 0;carry += an + bn;rs.push_back(carry % 10);carry /= 10;}}void plusOne(vector<short> &a){if (a.empty()) a.push_back(1);else{int i = 0;while (i < (int)a.size() && 9 == a[i]) a[i++] = 0;if (i == (int)a.size()) a.push_back(1);else a[i]++;}}void getTbl(){tbl0[0].push_back(0); tbl0[1].push_back(0);tbl1[0].push_back(0); tbl1[1].push_back(0);for (int i = 2; i < MAX_N; i++){addLargeNum(tbl0[i], tbl1[i-1], tbl0[i-1]);addLargeNum(tbl1[i], tbl0[i-1], tbl1[i-1]);if (!(i&1)) plusOne(tbl1[i]);}}int main(){getTbl();int n;while (scanf("%d", &n) != EOF){vector<short> &a = tbl1[n];short m = (short)tbl1[n].size();for (short i = m-1; i >= 0; i--){printf("%d", a[i]);}putchar('\n');}return 0;}



HDU Computer Transformation1041 題解

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.