每日OJ题_子序列dp⑤_力扣1218. 最长定差子序列

目录

[力扣1218. 最长定差子序列](#力扣1218. 最长定差子序列)

解析代码


力扣1218. 最长定差子序列

1218. 最长定差子序列

难度 中等

给你一个整数数组 arr 和一个整数 difference,请你找出并返回 arr 中最长等差子序列的长度,该子序列中相邻元素之间的差等于 difference

子序列 是指在不改变其余元素顺序的情况下,通过删除一些元素或不删除任何元素而从 arr 派生出来的序列。

示例 1:

复制代码
输入:arr = [1,2,3,4], difference = 1
输出:4
解释:最长的等差子序列是 [1,2,3,4]。

示例 2:

复制代码
输入:arr = [1,3,5,7], difference = 1
输出:1
解释:最长的等差子序列是任意单个元素。

示例 3:

复制代码
输入:arr = [1,5,7,8,5,3,4,2,1], difference = -2
输出:4
解释:最长的等差子序列是 [7,5,3,1]。

提示:

  • 1 <= arr.length <= 10^5
  • -10^4 <= arr[i], difference <= 10^4
cpp 复制代码
class Solution {
public:
    int longestSubsequence(vector<int>& arr, int difference) {

    }
};

解析代码

这道题和 力扣300. 最长递增子序列有⼀些相似,但仔细读题就会发现,本题的 arr.lenght 高达10^5 ,使用 O(N^2) 的 lcs 模型⼀定会超时。

那么它有什么信息是力扣300. 最长递增子序列的呢?是定差。之前只知道要递增,不知道前一个数应当是多少,现在我们可以计算出前一个数是多少了,就可以用数值来定义 dp 数组的值,并形成状态转移。这样,就把已有信息有效地利用了起来。

**状态表示:**dpi 表示:以 i 位置的元素为结尾所有的子序列中,最长的等差子序列的长度。

状态转移方程: 对于 dpi ,上一个定差子序列的取值定为 arri - difference 。只要找到以上一个数字为结尾的定差子序列长度的 dparr\[i - difference] ,然后加上 1 ,就是以 i 为结尾的定差子序列的长度。 因此这里可以选择使用哈希表做优化。把元素和dpj 绑定,放进哈希表中。甚至不用创建 dp 数组,直接在哈希表中做动态规划。

初始化、填表顺序、返回值:

刚开始的时候,需要把第一个元素放进哈希表中, hasharr\[0] = 1 。

从左往右填表,最后返回dp表的最大值即可。

cpp 复制代码
class Solution {
public:
    int longestSubsequence(vector<int>& arr, int difference) {
        // dp[i] 表示:以 i 位置的元素为结尾所有的子序列中,最长的等差子序列的长度。
        int n = arr.size(), ret = 1;
        unordered_map<int, int> dpHash(n);
        dpHash[arr[0]] = 1;
        for(int i = 1; i < n; ++i)
        {
            // if(dpHash[arr[i] - difference]) // b存在
            //     dpHash[arr[i]] = dpHash[arr[i] - difference] + 1;
            // else
            //     dpHash[arr[i]] = 1;
            dpHash[arr[i]] = dpHash[arr[i] - difference] + 1; // 不存在就是0,直接加
            ret = max(ret, dpHash[arr[i]]);
        }
        return ret;
    }
};
相关推荐
好评1243 小时前
【C++】智能指针全解
c++·智能指针
bIo7lyA8v3 小时前
算法稳定性分析中的随机扰动建模的技术8
算法
是阿建吖!3 小时前
【Linux】信号
android·linux·c语言·c++
城北徐宫3 小时前
Linux信号深度解剖:5种产生、3张表、4次切换
linux·c++·学习
liulilittle3 小时前
论 Linux 内核态全局稳态带宽的卡尔曼估计与工程实现
linux·服务器·网络·c++·计算机网络·tcp·通信
XBodhi.3 小时前
Visual Studio C++ 语法错误: 缺少“;”(在“return”的前面)
开发语言·c++·visual studio
科研online4 小时前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy4 小时前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯4 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b5 小时前
算法复杂度的实验验证与误差分析的技术8
算法