設置 | 登錄 | 註冊

目前共有2篇帖子。

【試題】第39級台階

1樓 巨大八爪鱼 2016-3-18 21:21
#include <stdio.h>

int count = 0;
char str[100];

void search(int nStaircases, int nSteps = 0)
{
    if (nStaircases < 0) // 不能多走幾階梯
        return;
    if (nStaircases == 0) // 走完了所有階梯時
    {
        if (nSteps % 2 == 0) // 走了剛好偶數步
        {
            str[nSteps] = '\0';
            //puts(str);
            count++; // 方案可行
        }
        return;
    }
    
    str[nSteps] = '1';
    search(nStaircases - 1, nSteps + 1); // 走一步
    str[nSteps] = '2';
    search(nStaircases - 2, nSteps + 1); // 走兩步
}

int main(void)
{
    search(39);
    printf("%d\n", count);
    return 0;
}
2樓 巨大八爪鱼 2016-3-18 21:23
這道題比較簡單,關鍵是要讀懂題。
其實就是要求計算偶數個1和2相加等於39的算式有多少個。

內容轉換:

回覆帖子
內容:
用戶名: 您目前是匿名發表。
驗證碼:
看不清?換一張
©2010-2025 Purasbar Ver3.0 [手機版] [桌面版]
除非另有聲明,本站採用知識共享署名-相同方式共享 3.0 Unported許可協議進行許可。