栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java递归求斐波那契数列的第n项

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java递归求斐波那契数列的第n项

斐波那契数列指的是这样一个数列 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368…
这个数列从第3项开始,每一项都等于前两项之和。

递归就是自己调用自己呗
下面是代码

import java.util.Scanner;
//递归求斐波那契数列的第n个数值
//递归就是自己调用自己
class evaluate//求值类
{
	private int a1=0;
	private int a2=1;
	public int gettern(){//输入n的值并返回
		Scanner scan = new Scanner(System.in);
		int n=scan.nextInt();
		return n;
	}
	public int nvalue(int n){//递归求得第n项的值
		if(n==0){
			return 0;
		}else if(n==1){
			return 1;
		}else{
			return nvalue(n-1)+nvalue(n-2);//递归
		}	
	}
}
class Getn 
{
	public static void main(String[] args) 
	{
		evaluate e1 = new evaluate();
		int n = e1.gettern();
		int value = e1.nvalue(n);
		System.out.println("斐波那契数列的第"+n+"个数值为"+value);
	}
}

缺点:并且递归可慢了,求第50项可慢可慢,解决慢的方法用循环,但是这样求出来第50项也是一个负数,毕竟第50项超过人家int类型的范围了
咱们也就用用递归知道怎么用就行了

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/332301.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号