当前位置: 首页 > news >正文

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)。

代码:

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)

http://www.dtcms.com/a/44917.html

相关文章:

  • 西门子S7-1200比较指令
  • @[TOC](Java实现 图书管理系统) # 一、菜单 该图书管理系统的菜单界面主要有以下两种: **管理员菜单:** **用户菜单:**
  • 线程池--深入一些
  • 从0-1学习Mysql第十二章: 常见问题与故障排查
  • 刷屏(0和1)
  • 模块七_面向对象
  • 解决android studio(ladybug版本) gradle的一些task突然消失了
  • iOS for...in 循环
  • Phpstudy中的MySQL无法正常启动或启动后自动暂停,以及sqlilab环境搭建出现的问题解决方法
  • ORM Bee V2.5.2.x 发布,支持 CQRS; sql 性能分析;更新 MongoDB ORM分片
  • 014存储期(时间)
  • Qt之QStateMachine等待
  • C++20 Lambda表达式新特性:包扩展与初始化捕获的强强联合
  • Is Noise Conditioning Necessary for Denoising Generative Models?论文阅读笔记
  • 开源向量数据库Milvus简介
  • RNN实现精神分裂症患者诊断(pytorch)
  • 在日常工作中,有一块新磁盘,如何扩容到vm中,具体命令是什么?
  • XSL 语言:XML 样式表的语言基础与应用
  • 初识uniApp
  • 【Java项目】基于SpringBoot的Java学习平台
  • 在Ubuntu中,某个文件的右下角有一把锁的标志是什么意思?
  • 在什么情况下需要使用光谱相机呢?
  • 《Neurocomputing》投稿历程
  • 从UNIX到Linux:操作系统进化史与开源革命
  • 模拟器DTXMania的DTX文件格式规范
  • 挺逼真:AI绘画+AI扩图,已解锁,无限次生成~~~
  • 「Selenium+Python自动化从0到1②|2025浏览器操控7大核心API实战(附高效避坑模板))」
  • 基于trl复现DeepSeek-R1的GRPO训练过程
  • python之线程池ThreadPoolExecutor笔记
  • 单片机栈和堆、FALSH、区别