P1255 数楼梯

题目传送门

一、递推+高精度

#include <bits/stdc++.h>

using namespace std;
const int N = 5010;

/**
 * 功能:高精度加法模板
 * @param A
 * @param B
 * @return
 */
vector<int> add(vector<int> &A, vector<int> &B) {
    if (A.size() < B.size()) return add(B, A);
    int t = 0;
    vector<int> C;
    for (int i = 0; i < A.size(); i++) {
        t += A[i];
        if (i < B.size()) t += B[i];
        C.push_back(t % 10);
        t /= 10;
    }
    if (t) C.push_back(t);
    return C;
}

int main() {
    int n;
    cin >> n;
    if (n <= 2) {
        printf("%d", n);
        return 0;
    }

    vector<int> A, B, C;
    A.push_back(1);
    B.push_back(2);

    for (int i = 3; i <= n; i++) {
        C = add(A, B);
        //A<---B
        A.assign(B.begin(), B.end());
        //B<---C
        B.assign(C.begin(), C.end());
    }
    //倒序输出结果
    for (int i = B.size() - 1; i >= 0; i--)printf("%d", B[i]);
    return 0;
}

二、深度优先【无法AC】

#include <bits/stdc++.h>

using namespace std;
int n;
int ways;

/**
 * @param level     现在站在第几阶台阶上
 * N阶楼梯上楼问题:一次可以走两阶或一阶,请把所有行走方式打印出来。
 * 测试数据: 5  输出结果 一共有8种走法
 * 测试数据: 15 输出结果 一共有987种走法
 * 方案 :回溯法+递归
 */
void dfs(int level) {
    //如果可以走到第n个台阶,表示可以成功登顶,算是一个解决方案
    if (level == n) ways++;

    //2种分枝
    for (int i = 1; i <= 2; i++)
        if (level + i <= n) dfs(level + i);
}

int main() {
    cin >> n;
    dfs(0);
    printf("一共 %d 种方法。\n", ways);
    return 0;
}

三、深度优先+输出路径【无法AC】

#include <bits/stdc++.h>

using namespace std;
const int N = 110;
int a[N];
int n;
int ways;

/**
 * @param step      走了几次
 * @param level     现在站在第几阶台阶上
 * N阶楼梯上楼问题:一次可以走两阶或一阶,请把所有行走方式打印出来。
 * 测试数据: 5  输出结果 一共有8种走法
 * 测试数据: 15 输出结果 一共有987种走法
 * 方案 :回溯法+递归
 */
void dfs(int level, int step) {
    if (level == n) {
        ways++;
        //输出结果
        for (int i = 0; i < step; i++)printf("%d\t", a[i]);
        printf("\n");
    }
    //2种分枝
    for (int i = 1; i <= 2; i++) {
        //可行
        if (level + i <= n) {
            a[step] = i;//记录解向量
            dfs(level + i, step + 1);
        }
    }
}

int main() {
    cin >> n;
    dfs(0, 0);
    printf("一共 %d 种方法。\n", ways);
    return 0;
}

posted @ 2021-11-24 08:41  糖豆爸爸  阅读(111)  评论(0编辑  收藏  举报
Live2D