Problem Description
度熊面前有一个全是由1构成的字符串,被称为全1序列。你可以合并任意相邻的两个1,从而形成一个新的序列。对于给定的一个全1序列,请计算根据以上方法,可以构成多少种不同的序列。
Input
这里包括多组测试数据,每组测试数据包含一个正整数N,代表全1序列的长度。
1≤N≤200
Output
对于每组测试数据,输出一个整数,代表由题目中所给定的全1序列所能形成的新序列的数量。
Sample Input
1 3 5
Sample Output
1 3 8
#include <iostream>
#include <memory.h>
using namespace std;
int a[205][205]={0};
int main() {
a[1][200] = 1;
a[2][200] = 2;
//把数的每一位都拆开,放在数组的不同位中去
for(int i=3; i<=200; i++)
{
for(int j=200; j>=0; j--)
{
//相当于两个数带进位的相加,个位和个位相加,十位和十位相加
a[i][j] = a[i][j] + a[i-1][j] + a[i-2][j];
if(a[i][j]>9)
{
a[i][j-1] = a[i][j] / 10;
a[i][j] = a[i][j] %10;
}
}
}
int n;
while(cin>>n)
{
int j = 0;
while(a[n][j]==0) j++;
for(; j<=200; j++)
{
cout<<a[n][j];
}
cout<<endl;\
}
}