实全软件科技有限公司

衡斅-衡量使人觉悟

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  31 随笔 :: 10 文章 :: 67 评论 :: 68057 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

面试题:一列数的规则如下: 112358132134...... 求第30位数是多少, 用递归算法实现(C#)。

 

         还是面试题,从一个工作四年多的软件公司(网欣软件)出来后,这些天一直在面试,却没有找到合适的。看到这些基础的面试题,做起来还真有点吃力,好久没去看这些基础的东西,有点生疏了。

         看到这个题目,从数列的规则可以看出:从第三位数开始,数值等于前两个数之和,求第30位数,那就是求出28位和29位之和,而第29位数就是27位和28位数之和。当时按照这个思路进行编码,却没能在试卷上实现。

         回家后,到网上搜索一下,大部分的答案都类似这样结果:

         class Program

    {

        static void Main(string[] args)

        {

            Console.WriteLine(string.Format("{0}", Foo(50)));

            Console.Read();

        }

 

        public static long Foo(int i)

        {

            long result = 0;

            if (i <= 0)

                return 0;

            else if (i > 0 && i <= 2)

                return 1;

            else

                result = Foo(i - 1) + Foo(i - 2);

 

            //Console.Write(string.Format("{0}\t", result));

 

            return result;

        }

    }

         这样的程序性能极其低下,显示50位的结果就基本无法显示,完全误导开发人员。为此,将我的思路实现为程序,程序代码如下:

         class Program

    {

        static void Main(string[] args)

        {

            Console.WriteLine(string.Format("{0}", GetResult(91)));

            Console.Read();

        }

       

        public static long GetResult(int number)

        {

            if(number <= 2)

                return 1;

            return GetResult(1,1,3,number);

        }

 

        private static long GetResult(long left, long right, int count, int number)

        {

            long result = left + right;

           

            Console.Write(string.Format("{0}\t", result));

            //获取下个数

            if(count < number)

            {

                count   = count + 1;

                //进行数据转移

                left    = right;

                right   = result;

                //递归调用

                result = GetResult(left, right, count, number);

            }

            return result;

        }

    }

    由于数据、机器原因,可以看到第91位计算结果,后面的显示就不正常了。有没更好的方法计算出更多位数,欢迎赐教!

    不当之处,欢迎指正!

        

posted on   衡斅  阅读(4033)  评论(10编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示