标题:第四届蓝桥杯本科B组C语言题
只看楼主
m111
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2015-11-19
得分:0 
回复 9楼 beyondyf
楼主,我刚测试了一下,你的那个边界条件错了。
a(1) = 1 b(1) = 0
a(2) = 1 b(2) = 1

我的代码是:
程序代码:
/* ----递推 
设上到第n级台阶走奇数步的走法为a(n),走偶数步的走法为b(n)。那么,
a(n) = b(n-1) + b(n-2)
b(n) = a(n-1) + a(n-2)
边界条件
a(1) = 1 b(1) = 0
a(2) = 1 b(2) = 1
题目要的结果是b(39)
*/
#include <stdio.h>
int EvenStep(int even);

int OddStep(int odd){   //奇数 
    if( odd == 1){
        return 1;
    } 
    if(odd == 2){
        return 1;
    }
    
    return EvenStep(odd-1) + EvenStep(odd-2);
}

int EvenStep(int even){  //偶数 
    if( even == 1 ){
        return 0;
    }
    if( even == 2){
        return 1;
    }
    
    return OddStep(even-1) + OddStep(even-2);
} 

int main(){
    printf("%d\n", EvenStep(39));//总步数为偶数
    
    return 0;
} 

 如果有错误,希望指出,谢谢
2015-11-19 16:11



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-406414-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.932816 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved