• 【算法】Fibonacci(斐波那契数列)相关问题


    一、列出Fibonacci数列的前N个数

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    
    namespace Fibonacci
    {
        class Program
        {
            static void Main(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("
    ");
                    f1 = f1 + f2;
                    f2 = f2 + f1;
                }
            }
            
        }
    }

    若后续有相关问题,余则继续补充。

    愿诸位朋友及时指正!

  • 相关阅读:
    maven 查看依赖jar包,或获取版版本号 、license
    windows 强制关掉端口
    项目经理是如何选择的?
    windows 10 多系统引导下安装debian linux 系统 引导文件
    在 Mac 环境下 emulator 模拟器不能上网 Android Studio AVD
    WordPress
    使用blob对H5视频播放进行加密
    算法——动态规划
    算法——贪婪算法
    算法——权重最短路径算法
  • 原文地址:https://www.cnblogs.com/GeekDragon/p/9825765.html
Copyright © 2020-2023  润新知