剑指 Offer 10- I. 斐波那契数列
题目:
思路:
【1】首先公式已经出来了,F(N) = F(N-1)+F(N-2),那么其实考虑额外的辅助空间的话是比较方便的,但是这种会造成空间复杂度为O(N)。如果考虑减少空间复杂度的话,其实需要两个变量作为记录公式里面F(N-1)与F(N-2)的值。这种对于每次查找都要计算,如果考虑复用次数多的话其实上面那种会更优,毕竟空间换时间的本质就是占用一定空间,换取大量减少重复计算的过程。所以递归方式和循环方式都是可以的。
【2】其次考虑到限制,因为INT最大值为2147483647,而限制值为1000000007,如果考虑最终结果res%1000000007,那么其实如果INT出现溢出的话,结果很可能与理想不一样。所以每次计算之后其实都要考虑限制值这种才算是正常流程。
代码展示:
//时间0 ms击败100% //内存38 MB击败93.86% class Solution { public int fib(int n) { int a0 = 0, a1 = 1; if (n == 0) return a0; if (n == 1) return a1; int res = 0; for (int i = 2; i <= n; i++){ res = (a0 + a1)%1000000007; a0 = a1; a1 = res; } return res; } }
分类:
leetcode题目
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix