一、列出Fibonacci数列的前N个数using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace Fibonacci{ class Program { ...
一、列出Fibonacci数列的前N个数
using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace Fibonacci{ class Program { static void Main(get='_blank'>string[] args) { cal(20); cal2(20); //运行结果相同 } /*需求:列出Fibonacci数列的前N个数*/ //方案一:迭代N次,一次计算一项 public static void cal(int N) { int f1 = 1; int f2 = 1; int f = 0; for (int i = 1; i <= N; i++) { if (i == 1) { Console.Write(f1); Console.Write(" "); } else if (i == 2) { Console.Write(f2); } else { f = f1 + f2; f2 = f1; f1 = f; Console.Write(" "); Console.Write(f); } } } //方案二:迭代N/2次,一次计算两项 public static void cal2(int N) { int f1 = 1; int f2 = 1; for (int i = 1; i <= N / 2; i++) { Console.Write(" "); Console.Write(f1); Console.Write(" "); Console.Write(f2); f1 = f1 + f2; f2 = f2 + f1; } }
二、求出Fibonacci数列第N个数字(迭代法)
namespace Fibonacci{ class Program { static void Main(string[] args) { string N = Console.ReadLine(); int integer = Convert.ToInt32(N); Console.WriteLine("{0}",F(integer)); } /*需求:求出Fibonacci数列第N个数字*/ //迭代法 public static int F(int N) { if (N == 1) return 1; if (N == 2) return 1; else return F(N - 1) + F(N - 2); } }}
三、古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
问题分析:其兔子数目依旧是按1,1,2,3,5…的顺序进行排列。其本质仍为斐波那契数列。
解决:按照一中的方案二进行即可。
namespace Fibonacci{ class Program { static void Main(string[] args) { //与方案二相同 string N = Console.ReadLine(); int integer = Convert.ToInt32(N); int f1 = 1; int f2 = 1; for (int i = 1; i <= integer; i++) { Console.Write("{0} {1}",f1,f2); Console.Write(" "); if (i%2==0) Console.WriteLine("\n"); f1 = f1 + f2; f2 = f2 + f1; } } }}
后续有相关问题继续补充。
愿诸位朋友及时指正!
海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com
原标题:【算法】Fibonacci(斐波那契数列)相关问题
关键词:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。