当前位置:首页 > 算法 > 正文内容

爬楼梯问题的简单实现-递归

chanra1n5年前 (2019-11-06)算法5058

如楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编写程序计算共有多少种不同的走法。例如,当n=3时,共有3种走法,即1+1+1,1+2,2+1,当n=4时,共有5种走法,即

1+1+1+1,2+2,2+1+1,1+2+1,1+1+2。

算法分析:设n阶台阶的走法数为f( n ),显然有:

(1)f( 1 )= 1               n = 1;

(2)f( 2 )= 2               n = 2;

(3)f( n )=f( n-1 )+ f( n-2 )   n > 2。

#include <iostream>
using namespace std;
int Fstairs( int n )
{
    if ( n  == 1 || n  == 2 )
        return n;
    return  Fstairs( n-1 ) + Fstairs( n-2 );    
}
int main()
{
	int n=1;
	cout << "请输入要要爬的楼梯数为?"<< endl;
	cin >> n;
	cout << Fstairs(n) << endl;
	return 0;
}
#include <stdio.h>
int Fstairs( int n )
{
    if ( n  == 1 || n  == 2 )
        return n;
    return  Fstairs( n-1 ) + Fstairs( n-2 );    
}
int main()
{
	int n=1;
	printf("请输入要要爬的楼梯数为?");
	scanf("%d",&n);
	printf("%d",Fstairs(n));
	return 0;
}


扫描二维码推送至手机访问。

版权声明:本文由我的FPGA发布,如需转载请注明出处。

本文链接:https://myfpga.cn/index.php/post/51.html

分享给朋友:

“爬楼梯问题的简单实现-递归” 的相关文章

顺序表算法应用

顺序表算法应用

利用顺序表数据类型解决实际问题,内容如下:(1) 定义顺序表结构数组对象,最多能存100个数据;(2) 调用创建函数初始化顺序表为1,5,96,45,3,6,4,88,7,36(3) 调用输出函数,要求输出当前这个数据结构中的所有数据;(4) 调用插入函数,要求在当前存放数据的第一个位置插入一个值为...

广义表输出二叉树

广义表输出二叉树

广义表输出二叉树用到的主要是递归,递归的整个过程类似于栈,一层一层进去,最终会一层一层退出来,进去和退出的顺序跟栈的性质一致。#include<stdio.h> #include<stdlib.h> typedef struct tnode{ ch...

(LeetCode刷题)1. 两数之和

(LeetCode刷题)1. 两数之和

题目解答一:/**  * Note: The returned array must be malloced, assume caller calls free(). &nbs...

(LeetCode刷题)2. 两数相加

(LeetCode刷题)2. 两数相加

题目解答一:简单实现思路:先遍历完两个链表,把各自的数字存入两个数组,然后对应位置的数相加,若结果大于10就进位到更高位的数。/**  * Definition for singly-linked list->  * s...

(LeetCode刷题)3. 无重复字符的最长子串

(LeetCode刷题)3. 无重复字符的最长子串

题目:解法一:class Solution(object):     def lengthOfLongestSubstring(self,s):        &nb...