一千题,No.0001(统计方案)

描述

在一无限大的二维平面中,我们做如下假设:

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;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值