C# 4种方法计算斐波那契数列 Fibonacci

简介: F1:  迭代法 最慢,复杂度最高 F2:  直接法   F3:  矩阵法 参考《算法之道(The Way of Algorithm)》第38页-魔鬼序列:斐波那契序列   F4:  通项公式法    由于公式中包含根号5,无法取得精确的结果,数字越大误差越大   1 using System; 2 using System.

F1:  迭代法

最慢,复杂度最高

F2:  直接法

 

F3:  矩阵法

参考《算法之道(The Way of Algorithm)》第38页-魔鬼序列:斐波那契序列

 

F4:  通项公式法

 

 由于公式中包含根号5,无法取得精确的结果,数字越大误差越大

 

  1 using System;
  2 using System.Diagnostics;
  3 
  4 
  5 namespace Fibonacci
  6 {
  7     class Program
  8     {
  9         static void Main(string[] args)
 10         {
 11             ulong result;
 12 
 13             int number = 10;
 14             Console.WriteLine("************* number={0} *************", number);
 15 
 16             Stopwatch watch1 = new Stopwatch();
 17             watch1.Start();
 18             result = F1(number);
 19             watch1.Stop();
 20             Console.WriteLine("F1({0})=" + result + "  耗时:" + watch1.Elapsed, number);
 21 
 22             Stopwatch watch2 = new Stopwatch();
 23             watch2.Start();
 24             result = F2(number);
 25             watch2.Stop();
 26             Console.WriteLine("F2({0})=" + result + "  耗时:" + watch2.Elapsed, number);
 27 
 28             Stopwatch watch3 = new Stopwatch();
 29             watch3.Start();
 30             result = F3(number);
 31             watch3.Stop();
 32             Console.WriteLine("F3({0})=" + result + "  耗时:" + watch3.Elapsed, number);
 33 
 34             Stopwatch watch4 = new Stopwatch();
 35             watch4.Start();
 36             double result4 = F4(number);
 37             watch4.Stop();
 38             Console.WriteLine("F4({0})=" + result4 + "  耗时:" + watch4.Elapsed, number);
 39 
 40             Console.WriteLine();
 41 
 42             Console.WriteLine("结束");
 43             Console.ReadKey();
 44         }
 45 
 46         /// <summary>
 47         /// 迭代法
 48         /// </summary>
 49         /// <param name="number"></param>
 50         /// <returns></returns>
 51         private static ulong F1(int number)
 52         {
 53             if (number == 1 || number == 2)
 54             {
 55                 return 1;
 56             }
 57             else
 58             {
 59                 return F1(number - 1) + F1(number - 2);
 60             }
 61             
 62         }
 63 
 64         /// <summary>
 65         /// 直接法
 66         /// </summary>
 67         /// <param name="number"></param>
 68         /// <returns></returns>
 69         private static ulong F2(int number)
 70         {
 71             ulong a = 1, b = 1;
 72             if (number == 1 || number == 2)
 73             {
 74                 return 1;
 75             }
 76             else
 77             {
 78                 for (int i = 3; i <= number; i++)
 79                 {
 80                     ulong c = a + b;
 81                     b = a;
 82                     a = c;
 83                 }
 84                 return a;
 85             }
 86         }
 87 
 88         /// <summary>
 89         /// 矩阵法
 90         /// </summary>
 91         /// <param name="n"></param>
 92         /// <returns></returns>
 93         static ulong F3(int n)
 94         {
 95             ulong[,] a = new ulong[2, 2] { { 1, 1 }, { 1, 0 } };
 96             ulong[,] b = MatirxPower(a, n);
 97             return b[1, 0];
 98         }
 99 
100         #region F3
101         static ulong[,] MatirxPower(ulong[,] a, int n)
102         {
103             if (n == 1) { return a; }
104             else if (n == 2) { return MatirxMultiplication(a, a); }
105             else if (n % 2 == 0)
106             {
107                 ulong[,] temp = MatirxPower(a, n / 2);
108                 return MatirxMultiplication(temp, temp);
109             }
110             else
111             {
112                 ulong[,] temp = MatirxPower(a, n / 2);
113                 return MatirxMultiplication(MatirxMultiplication(temp, temp), a);
114             }
115         }
116 
117         static ulong[,] MatirxMultiplication(ulong[,] a, ulong[,] b)
118         {
119             ulong[,] c = new ulong[2, 2];
120             for (int i = 0; i < 2; i++)
121             {
122                 for (int j = 0; j < 2; j++)
123                 {
124                     for (int k = 0; k < 2; k++)
125                     {
126                         c[i, j] += a[i, k] * b[k, j];
127                     }
128                 }
129             }
130             return c;
131         }
132         #endregion
133 
134         /// <summary>
135         /// 通项公式法
136         /// </summary>
137         /// <param name="n"></param>
138         /// <returns></returns>
139         static double F4(int n)
140         {
141             double sqrt5 = Math.Sqrt(5);
142             return (1/sqrt5*(Math.Pow((1+sqrt5)/2,n)-Math.Pow((1-sqrt5)/2,n)));
143         }
144     }
145 }

 

n=50时

 

n=500

 

 n=5000

 

 n=50000

 

 n=5000000

 

目录
相关文章
|
2月前
|
开发框架 .NET 程序员
C# 去掉字符串最后一个字符的 4 种方法
在实际业务中,我们经常会遇到在循环中拼接字符串的场景,循环结束之后拼接得到的字符串的最后一个字符往往需要去掉,看看 C# 提供了哪4种方法可以高效去掉字符串的最后一个字符
299 0
|
1月前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
116 65
|
5月前
|
数据采集 数据可视化 测试技术
C#生成Selenium测试报告:实用方法与技巧
在C#中使用Selenium进行自动化测试时,结合代理IP和ExtentReports能增强测试安全性和报告质量。安装必备工具如Selenium WebDriver、NUnit和ExtentReports。在测试设置中,配置代理(如亿牛云爬虫代理)以隐藏IP,通过ChromeOptions定制UserAgent,并添加Cookie。测试代码示例展示了如何打开网页、执行搜索并生成详细的测试报告。使用ExtentReports可创建可视化测试结果,便于团队分析。
C#生成Selenium测试报告:实用方法与技巧
|
11天前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
13天前
|
C# UED SEO
C# 异步方法async / await任务超时处理
通过使用 `Task.WhenAny`和 `Task.Delay`方法,您可以在C#中有效地实现异步任务的超时处理机制。这种方法允许您在指定时间内等待任务完成,并在任务超时时采取适当的措施,如抛出异常或执行备用操作。希望本文提供的详细解释和代码示例能帮助您在实际项目中更好地处理异步任务超时问题,提升应用程序的可靠性和用户体验。
40 3
|
1月前
|
存储 C#
【C#】大批量判断文件是否存在的两种方法效率对比
【C#】大批量判断文件是否存在的两种方法效率对比
40 1
|
1月前
|
C#
C#的方法的参数传递
C#的方法的参数传递
18 0
|
1月前
|
数据可视化 程序员 C#
C#中windows应用窗体程序的输入输出方法实例
C#中windows应用窗体程序的输入输出方法实例
46 0
|
2月前
|
C#
C#一分钟浅谈:Lambda 表达式和匿名方法
本文详细介绍了C#编程中的Lambda表达式与匿名方法,两者均可用于定义无名函数,使代码更简洁易维护。文章通过基础概念讲解和示例对比,展示了各自语法特点,如Lambda表达式的`(parameters) =&gt; expression`形式及匿名方法的`delegate(parameters)`结构。并通过实例演示了两者的应用差异,强调了在使用Lambda时应注意闭包问题及其解决策略,推荐优先使用Lambda表达式以增强代码可读性。
44 8
|
3月前
|
图形学 C# 开发者
全面掌握Unity游戏开发核心技术:C#脚本编程从入门到精通——详解生命周期方法、事件处理与面向对象设计,助你打造高效稳定的互动娱乐体验
【8月更文挑战第31天】Unity 是一款强大的游戏开发平台,支持多种编程语言,其中 C# 最为常用。本文介绍 C# 在 Unity 中的应用,涵盖脚本生命周期、常用函数、事件处理及面向对象编程等核心概念。通过具体示例,展示如何编写有效的 C# 脚本,包括 Start、Update 和 LateUpdate 等生命周期方法,以及碰撞检测和类继承等高级技巧,帮助开发者掌握 Unity 脚本编程基础,提升游戏开发效率。
81 0