作者共發了2篇帖子。 內容轉換:不轉換▼
 
點擊 回復
211 1
【试题】第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的算式有多少个。

回復帖子

內容:
用戶名: 您目前是匿名發表
驗證碼:
(快捷鍵:Ctrl+Enter)
 

本帖信息

點擊數:211 回複數:1
評論數: ?
作者:巨大八爪鱼
最後回復:巨大八爪鱼
最後回復時間:2016-3-18 21:23
 
©2010-2024 Arslanbar Ver2.0
除非另有聲明,本站採用共享創意姓名標示-相同方式分享 3.0 Unported許可協議進行許可。