台阶问题学习笔记

        最近浏览CSDN的帖子看到了SillyBenzhu的关于列举走楼梯的解决方案,感觉挺好玩,所以试一下。

首先这个问题如果想很简单的解决就用递归法来解决,否则就用SillyBenzhu的回溯加递归的方法。

递归法

#include<stdio.h>
int f(int n)
{
    if (n <= 0)
        return 0;
    else if (n == 1)
        return 1;
    else if (n == 2)
        return 2;
    else
        return f(n-1)+f(n-2);
}
void main(){
int n;
int s=0;
printf("input numbers of step n:");  
scanf("%d",&n);  
s=f(n);
printf("%d\n",s);
}


修改SillyBenzhu的回溯+递归的方法,使之可以直接适用于Windows的VC++编译器。


/* 
 * N阶楼梯上楼问题:一次可以走两阶或一阶,请把所有行走方式打印出来。 
 * 测试数据: 5  输出结果 一共有8种走法 
 * 测试数据: 15 输出结果 一共有987种走法 
 * 方案 :回溯法+递归 
 */  
#include <stdlib.h>  
#include <stdio.h>  
int a[100] = {0};  
int n;
  
int GoUp(int level,int step)  
{  //level 是a[]下标,它的含义是经过多少次(一次可以走一阶或者两阶)走完楼梯(level+1) 
	//step 是台阶计数 ways 是多少条路径
    int i;  
    static int ways = 0;  
    if(step == n)//已经走到尽头  
    {  
        ways++;  
        for(i=0; i<level; i++)printf("%d\t",a[i]);  //一个a[]数组是一种爬楼梯方式
        printf("\n");  
        return ways;  
    }  
    for(i=1; i<=2; i++)//2种分支,代表该次走一阶或者两阶
    {  
        if(step+i <= n)//判断该次走i阶是否可行
        {  
            a[level] = i;//记录解向量  
            //继续递归走下一步,注意递归自动隐含level和step的回溯过程!!  
            GoUp(level+1,step+i);  
        }  
    }  
    return ways;  
}  
int main()  
{  
    int i;  
	
   printf("input numbers of step n:");
    scanf("%d",&n);
    i = GoUp(0,0);  
    printf("Totally %d ways .\n",i);  
    return 1;  
}  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值