剑指Offer-斐波那契数列
题目描述#
大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。n<=39
思路#
思路一:
用递归求解,F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*)
思路二:
用迭代方法,用两个变量记录fn-1和fn-2
代码实现#
package Recursion;
/**
* 题目描述
* 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项。
* n<=39
* 思路:
* 在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*)
* 用文字来说,就是斐波那契数列列由 0 和 1 开始,之后的斐波那契数列系数就由之前的两数相加。
* 特别指出:0不是第一项,而是第零项。
*/
public class Solution03 {
public static void main(String[] args) {
System.out.println(Fibonacci_2(4));
}
/**
* 用递归直接求解
*
* @param n 斐波那契数列第n项
* @return 斐波那契数列第n项的值
*/
public static int Fibonacci(int n) {
if (n <= 0) {
return 0;
}
if (n <= 1) {
return n;
} else {
return Fibonacci(n - 1) + Fibonacci(n - 2);
}
}
/**
* 迭代方法,用两个变量记录fn-1和fn-2:
*
* @param n 斐波那契数列第n项
* @return 斐波那契数列第n项的值
*/
public static int Fibonacci_2(int n) {
int zero = 0, one = 1, fN = 0;
if (n <= 0) {
return 0;
} else if (n == 1) {
return 1;
} else {
//由zero和one保存中间结果
for (int i = 2; i <= n; i++) {
fN = one + zero;
zero = one;
one = fN;
}
return fN;
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?