匯東網


C 程序設計 - 青蛙跳臺階

[編輯] [转简体]
|
作者:huidong | 分類:【編程】NOJ 和 C 程序設計習題
[ 5 瀏覽 0 評論 1 贊 1 踩 ]

概要
青蛙跳臺階,一共有 n 級臺階,每次可以上 1 級或者 2 級,問一共有幾種上去的方法

正文

斐波那契數列法(最優法)

甚至可以不要循環,直接用斐波那契數列通式算出答案

#include <stdio.h>

int main()
{
    int n = 4;    // 臺階數
    int p = 0, q = 1;    // 斐波那契數列的第 0, 1 項

    // 求斐波那契數列(1, 1, 2, 3, 5, ...)的第 n+1 項
    for (int i = 0; i < n; i++)
    {
        // p, q 所代表的項向前移動
        int sum = p + q;
        p = q;
        q = sum;
    }

    printf("%d", q);

    return 0;
}


遞歸法(數組優化重複計算)

遞歸法耗時長,重複計算多,且 n 過大時會爆棧。唯一的優點是寫起來稍微簡單一點,但是如果要優化的話也簡單不到哪去。

#include <stdio.h>

// 青蛙上 n 級臺階有幾種走法
int Frog(int n)
{
    static int ret[1024] = { 0 };

    if (n < 1024 && ret[n] != 0)
        return ret[n];

    int r;
    if (n <= 2)
        r = n;
    else
        r = Frog(n - 1) + Frog(n - 2);
    if (n < 1024)
        ret[n] = r;

    return r;
}

int main()
{
    int m;
    scanf("%d", &m);

    printf("%d", Frog(m));

    return 0;
}


[ 1] [ 1]


 評論區  0 條評論

+ 添加評論