永远八岁啦 2021-04-10 09:35 采纳率: 100%
浏览 14
已采纳

有大佬能解释一下为什么sum的值每次只加了1吗?[face]monkey2:012.png[/fac

有大佬能解释一下为什么sum的值每次只加了1吗?[face]monkey2:012.png[/face]
  • 写回答

1条回答 默认 最新

  • include_iostream_ 2021-04-10 14:10
    关注

    首先很显然的是,数列的分子和分母都是斐波那契数列,分子是分母的下一项。

    考虑a,b,c,d四个连续的斐波那契数列项:

    c=a+b,d=b+c

    任意一个分数项一定能写成d/c也就是(b+c)/(a+b)的形式。由于c>a,必有b+c>a+b,也即数列中每一项均大于1。我们考虑满足b+c>2(a+b)的情形,变形得-b+c-2a>0,带入c=a+b得-a>0,由于a总是非负(对于第一项2/1,有a=0,b=1,c=1,d=2,是唯一的a取0的项),这个式子不可能成立,也即d<=2c恒成立。c不为0,所以可以变形为d/c<=2。至此,我们证明了原数列每一项x满足1<x<=2。而且,只有第一项是2,后面的项都小于2。

    因此,double转换为int时,除了第一项求得2,后面的每个b/a隐式转换为整数,都得到1。(浮点数到整型转换规则:向0取整。换言之,符号保留,绝对值向下取整)

    解决方案:sum改成double型。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 关于大棚监测的pcb板设计
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)