算法题(95):斐波那契数列

审题:

本题需要我们找出与num距离最近的斐波那契数,并返回他们之间的距离(因为每次操作只会移动一位,所以距离就等于操作次数)

思路:
方法一:循环

由于斐波那契数列是一个单调递增的数列,所以我们只需要找出紧邻num的两个斐波那契数,然后判断一下是小于num的数距离更小还是大于num的数距离更小,输出更小的那个距离就可以了

我们可以利用循环,在当前斐波那契数小于num的前提下不断计算斐波那契数,最后出循环有两种情况

1.目前的最大斐波那契数等于num,直接返回0

2.大于num,进行判断,返回距离更小的值

解题:

(1)计算斐波那契数据

由于这里的数据可能会溢出,所以使用long long型数据。

left表示前两个位的数据,right表示前一个位的数据,利用他们进行计算就可以避免使用i来控制,达到动态使用数组的目的,减少开的空间

(2)输出数据

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值