描述
在一无限大的二维平面中,我们做如下假设:
1、每次只能移动一格;
2、不能向后走(假设你的目的地是“向上”,那么你可以向左走,可以向右走,也可以向上走,但是不可以向下走);
3、走过的格子立即塌陷无法再走第二次。
求走n步不同的方案数(2种走法只要有一步不一样,即被认为是不同的方案)。
输入描述
首先给出一个正整数C,表示有C组测试数据。
接下来的C行,每行包含一个整数n(n<=20),表示要走n步。
输出描述
请编程输出走n步的不同方案总数;
每组的输出占一行。
用例输入 1
2 1 2
用例输出 1
3 7
解题思路:
这道题为递归思路题,设前20项结果为Arr[20],
则Arr[n] = Arr[n-1](可以向上走的点) + Arr[n-1](可以向左走的点) + Arr[n-1](可以向右走的点);
其中:
Arr[n-1](可以向上走的点) = Arr[n-1];
Arr[n-1](可以向左走的点) = Arr[n-1](向左或向上走过来的点);
Arr[n-1](可以向右走的点) = Arr[n-1](向右或向上走过来的点);
则得出:
Arr[n] = Arr[n-1] + Arr[n-1](向左或向上走过来的点) + Arr[n-1](向右或向上走过来的点);
等价于:
Arr[n-1] + Arr[n-1] + Arr[n-1](向上走过来的点);
因为:Arr[n-1](向上走过来的点) = Arr[]n-2];
所以得出递归公式:
Arr[n] = 2Arr[n-1] +Arr[n-2];
c++代码如下
#include <iostream>
using namespace std;
int main()
{
int arr[99];
arr[0] = 1;
arr[1] = 3;
for(int i = 2;i<99;++i)
{
arr[i] = 2*arr[i-1] + arr[i-2];
}
int n;
cin >> n;
while(n--)
{
int num;
cin >> num;
cout << arr[num] << endl;
}
}