斐波那契数列 (C#)
斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34...
---百度百科
1 >>>数组 很好理解。
求第a位的数是多少?
第a位在循环中的下标是a-1。所以返回list[a-1];
public static int Fbnq(int a)
{
int[] list = new int[a];
list[] = ;
list[] = ;
for (var i = ; i < a; i++)
{
list[i] = list[i - ] + list[i - ];
}
return list[a - ];
}
2 >>>递归 很简洁,难理解,耗性能。
求第a位的数是多少?
递归有终点。本例终点就是a<=2的时候返回值是。
讲解:例如传入的a是30,求第30位是多少?
30进入函数执行:后边的语句。执行时 她发现需要Fbn1(29)+Fbn1(28),又发现29需要27+28,28需要27+26...... 直到到Fbn1(0)+Fbn1(1)【a<=2时】。函数有了值
然后一路加回去,便求出Fbnq(30).
public static int Fbnq1(int a)
{
return a <= ? : Fbnq1(a - ) + Fbnq1(a - );
}
学习阶段,有错误还望指出,谢谢!
斐波那契数列 (C#)的更多相关文章
- C#求斐波那契数列第30项的值(递归和非递归)
		
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
 - 斐波拉契数列加强版——时间复杂度O(1),空间复杂度O(1)
		
对于斐波拉契经典问题,我们都非常熟悉,通过递推公式F(n) = F(n - ) + F(n - ),我们可以在线性时间内求出第n项F(n),现在考虑斐波拉契的加强版,我们要求的项数n的范围为int范围 ...
 - js中的斐波那契数列法
		
//斐波那契数列:1,2,3,5,8,13…… //从第3个起的第n个等于前两个之和 //解法1: var n1 = 1,n2 = 2; for(var i=3;i<101;i++){ var ...
 - 剑指Offer面试题:8.斐波那契数列
		
一.题目:斐波那契数列 题目:写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项.斐波那契数列的定义如下: 二.效率很低的解法 很多C/C++/C#/Java语言教科书在讲述递归函数的时 ...
 - 算法: 斐波那契数列C/C++实现
		
斐波那契数列: 1,1,2,3,5,8,13,21,34,.... //求斐波那契数列第n项的值 //1,1,2,3,5,8,13,21,34... //1.递归: //缺点:当n过大时,递归 ...
 - 洛谷P1962 斐波那契数列 || P1349 广义斐波那契数列[矩阵乘法]
		
P1962 斐波那契数列 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 n 为整数 ...
 - Python递归及斐波那契数列
		
递归函数 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数.举个例子,我们来计算阶乘 n! = 1 * 2 * 3 * ... * n,用函数 fact(n)表示,可 ...
 - 简单Java算法程序实现!斐波那契数列函数~
		
java编程基础--斐波那契数列 问题描述:一只青蛙一次可以跳上1级台阶,也可以跳上2级.求该青蛙跳上一个n级的台阶总共有多少种跳法. 思路:可能出现的情况:(1) n=1 ,一种方法 ;(2)n=2 ...
 - js 斐波那契数列(兔子问题)
		
对于JS初学者来说,斐波那契数列一直是个头疼的问题,总是理不清思路. 希望看完这篇文章之后会对你有帮助. 什么是斐波那契数列 : 答: 斐波那契数列,又称黄金分割数列.因数学家列昂纳多·斐波那契(Le ...
 - 剑指offer三: 斐波拉契数列
		
斐波拉契数列是指这样一个数列: F(1)=1; F(2)=1; F(n)=F(n-1)+F(n); public class Solution { public int Fibonacci(int n ...
 
随机推荐
- 用Java写hello world
			
public class HelloWorld{ public static void main(String[] args){ System.out.println("hello worl ...
 - layui  layer弹框中表格的显示
			
场景描述:点击iframe里面的一个按钮,需要在父级弹出一个弹框表格. 问题描述:这个弹框的分页不能正常显示,如果把layer.open前面的parent去掉,就可以正常显示. 代码展示: paren ...
 - mvc根据绝对路径下载文件
			
首先页面需要一个a标签直接指向下载文件的Action并传值:图片地址,以及图片名称(记住要带后缀名的). 然后是Action里面的代码. SiteHelper.DownloadFile(fileUrl ...
 - Springboot  集成jpa使用
			
实体类 dao层 上面的查询 ,方法名友好命名的话,可以不写注解查询 findByXXXX MetadataSchemePO findBySchemeName(String schemeName); ...
 - Raiden Charge
			
2017年10月22 周日 这是个元气满满 值得纪念的一天(不好意思走错片场了) 虽然有各种乱遭的客观元素 但我们队确确实实地打铁了 那些我们轻视的 野鸡(误)大学 都在我们前面 都说知耻而后勇 虽然 ...
 - Vue 学习笔记 — css属性计算的问题
			
简书 今天在使用Vue时遇到一个问题:在切换css内联属性时某些特殊属性的计算会有问题,无法得到预期的结果. 例子: https://jsfiddle.net/blqw/cLwau40z/ 上面的页面 ...
 - linux 完全关闭tomcat
			
由于直接调用tomcat的 shutdown.sh 有时无法完全关闭掉tomcat,使用 ps -ef | grep tomcat 查找发现tomcat依然还存在,并未完全关掉.在 catalina. ...
 - 接口平台经常报server internal error(500)错误
			
查询日志,发现连接mysql报错,web页面显示server internal error(500) 解决方法:重启mysql服务器 systemctl start mysqld #安装mysql # ...
 - ASP.NET 下载文件方式
			
protected void Button1_Click(object sender, EventArgs e) { /* 微软为Response对象提供了一个新的方法TransmitFile来解决使 ...
 - Qt之自绘制饼图
			
1.说明 最近在搞绘图方面的工作,说实话C++的第三方绘图库并不算多,总之我了解的有:qtcharts.ChartDirector.qwt.kdchart和QCustomPlot.这几个库各有利弊. ...