菲波纳奇数字

using System;
using System.Collections.Generic;

namespace ConsoleApplication3
{
    
class Program
    {
        
private static List<int> resultList = new List<int>() { 01 };
        
static void Main(string[] args)
        {
            
int num = 89;
            
//给出一个数,使用递归计算出该数前的菲波纳奇数字序列,并判断是否是菲波纳奇数字
            try
            {
                TestMethod(num, resultList.Count 
- 1);
                
foreach (int item in resultList)
                {
                    Console.Write(item 
+ "\t");
                }
            }
            
catch (Exception ex)
            {
                Console.WriteLine(ex.ToString());
            }
            Console.ReadLine();
        }

        
static void TestMethod(int num, int index)
        {
            
if (null != resultList && resultList.Count >= 2)
            {
                
if (num == 0)
                    
return;

                
if (index > 0 && index <= resultList.Count)
                {
                    
int tmpSum = resultList[index - 1+ resultList[index];
                    
if (tmpSum < num)
                    {
                        resultList.Add(tmpSum);
                        TestMethod(num, resultList.Count 
- 1);
                    }
                    
else if (tmpSum == num)
                        resultList.Add(tmpSum);
                    
else
                        
throw new Exception("该数字不是菲波纳奇数字");
                }
            }
        }
    }
}

转载于:https://www.cnblogs.com/skyrickie/articles/2024911.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值