递归算法的一些具体应用

不可否认,许多公司的面试中都会或多或少涉及到一些算法相关的概念,下面我们来看两个示例,更好的理解递归算法的应用。

斐波那契数列

斐波那契数列(Fibonacci sequence)是以意大利数学家莱昂纳多·斐波那契命名的数列,其特点是每一项等于前两项之和,通常表示为F(0)=0、F(1)=1,F(n)=F(n-1)+F(n-2)(n≥2),数列形式为0、1、1、2、3、5、8、13、21、34......。

这个应该是非常简单的一个递归的应用了,对于许多高校中将 C 语言的时候一般都会提及,表达式为 Z = (n-2) + (n-1),相关的递归函数也非常好写,如下:

复制代码
int fibonacci(int n) {
        if (n == 1) {
            return 1; // 递归出口
        } else if (n == 2) {
            return 1;// 递归出口
        } else {
            return (fibonacci(n - 1) + fibonacci(n - 2));
        }
}

你,学会了吗?

相关推荐
rit843249933 分钟前
基于灰狼算法(GWO)优化支持向量回归机(SVR)参数C和γ的实现
c语言·算法·回归
蒋士峰DBA修行之路35 分钟前
实验五 静态剪枝
数据库·算法·剪枝
蒋士峰DBA修行之路38 分钟前
实验六 动态剪枝
数据库·算法·剪枝
Tim_101 小时前
【算法专题训练】20、LRU 缓存
c++·算法·缓存
B612 little star king2 小时前
力扣29. 两数相除题解
java·算法·leetcode
野犬寒鸦2 小时前
力扣hot100:环形链表(快慢指针法)(141)
java·数据结构·算法·leetcode·面试·职场和发展
时光追逐者2 小时前
C# 哈希查找算法实操
算法·c#·哈希算法
Jasmine_llq2 小时前
《P3825 [NOI2017] 游戏》
算法·游戏·枚举法·2-sat 算法·tarjan 算法·邻接表存储
Miraitowa_cheems2 小时前
LeetCode算法日记 - Day 38: 二叉树的锯齿形层序遍历、二叉树最大宽度
java·linux·运维·算法·leetcode·链表·职场和发展
wangzy19822 小时前
图形基础算法:如何将点与带曲线边的多边形位置关系算法做稳定
算法