LeetCode 873. Length of Longest Fibonacci Subsequence(2025/2/27每日一题)

昨天工作耽搁了,没来得及打卡每日一题,今日补上:

标题:Length of Longest Fibonacci Subsequence

题目:

例子:

Example 1:

复制代码
Input: arr = [1,2,3,4,5,6,7,8]
Output: 5
Explanation: The longest subsequence that is fibonacci-like: [1,2,3,5,8].

Example 2:

复制代码
Input: arr = [1,3,7,11,12,14,18]
Output: 3
Explanation: The longest subsequence that is fibonacci-like: [1,11,12], [3,11,14] or [7,11,18].

解题思路:

  • 先看这道题数量级是10的3次方,因此时间复杂度能接受O(n^2),但不能接受O(n^3)。
  • 确定解题用到的算法及数据结构:要求最长子序列的长度,只要确定子序列最前两个数字,后面的数字都是确定的,因此两层循环确定最前面两个数字,查看整个序列有多少个数字包含在序列中即可。查看的过程可以用unordered_set,查询时间复杂度为O(1)。

代码:

cpp 复制代码
class Solution {
public:
    int lenLongestFibSubseq(vector<int>& arr) {
        unordered_set<int> set(arr.begin(), arr.end());
        int res = 0;
        for(int i = 0; i < arr.size() - 2; i++){
            for(int j = i+1; j < arr.size() - 1; j ++){
                int len = 2, start = arr[i], second = arr[j], next = arr[i] + arr[j];
                while(next <= arr.back() && set.count(next)) {
                    len ++;
                    start = second;
                    second = next;
                    next = start + second;
                }
                if (len > 2) res = max(res, len);
            }
        }
        return res;
    }
};

O(N^2)<时间复杂度<O(N^3)

空间复杂度为O(N)

相关推荐
吃好睡好便好13 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅14 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue16 小时前
三角形数
笔记·算法·数论·组合数学
念何架构之路17 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星17 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑17 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光18 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩18 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947318 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ19 小时前
单词拆分----dp
算法