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

​Fibonacci数列的初步实现-递归

chanra1n6年前 (2019-11-06)算法5405

Fibonacci数列为:1、1、2、3、5、8、13、21、…,即 Fibonacci(1)=1; Fibonacci(2)=1;Fibonacci(n)=Fibonacci(n-1)+ Fibonacci(n-2)(当n>2时)。

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


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

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

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

分享给朋友:

“​Fibonacci数列的初步实现-递归” 的相关文章

算法初步

算法初步

假设我让你计算1+2+3+...+5000等于多少,有两种常见的方法:    1、按部就班累加    2、使用公式,(首项+末项)*项数/2假设你使用第一种方法从头到尾不出错的计算,可能也需要几个小时才能计算出来,但是如...

C语言判断素数

C语言判断素数

素数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数。思路:设m为要判断的数,m 不必被 2 ~ m-1 之间的每一个整数去除,只需被 2 ~  之间的每一个整数去除就可以了。如果 m 不能被 2 ~  间任一整数整除,m 必定是素数。例如判别 17...

广义表输出二叉树

广义表输出二叉树

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

顺序和二分法查找 (C C++)

顺序和二分法查找 (C C++)

#include<stdio.h> #include<stdlib.h> #define MAXSIZE 100 int cnt=0;//定于总共有多少个成员  typedef int KeyType; //...

(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...