1027. 最长等差数列【leetcode】/动态规划

1027. 最长等差数列

给你一个整数数组 nums,返回 nums 中最长等差子序列的长度。

回想一下,nums 的子序列是一个列表 nums[i1], nums[i2], ..., nums[ik] ,且 0 <= i1 < i2 < ... < ik <= nums.length - 1。并且如果 seq[i+1] - seq[i]( 0 <= i < seq.length - 1) 的值都相同,那么序列 seq 是等差的。

示例 1
输入 :nums = [3,6,9,12]
输出 :4
解释: 整个数组是公差为 3 的等差数列。

示例 2
输入 :nums = [9,4,7,2,10]
输出 :3
解释:最长的等差子序列是 [4,7,10]。

示例 3
输入 :nums = [20,1,15,3,10,5,8]
输出 :4
解释:最长的等差子序列是 [20,15,10,5]。

提示:

2 <= nums.length <= 1000

0 <= nums[i] <= 500

动态规划

如果开数组会爆,只能开容器。

dp[i][j]表示第i个元素及前面元素的公差为j的最长等差数列的长度,因为公差范围最小可以到-500,于是每个公差进行处理+500使其非负。

cpp 复制代码
class Solution {
public:
    int longestArithSeqLength(vector<int>& nums) 
    {
        vector<vector<int> > dp(1005,vector<int>(1001,0));
        int res=0;
        int len=nums.size();
        for(int i=1;i<len;i++)
        {
            for(int j=0;j<i;j++)
            {
                int k=nums[i]-nums[j]+500;
                if(dp[j][k]+1>dp[i][k]) dp[i][k]=dp[j][k]+1;
                if(dp[i][k]>res) res=dp[i][k];
            }
        }
        return res+1;
    }
};
相关推荐
叶子野格1 分钟前
《C语言学习:编程例题》8
c语言·开发语言·c++·学习·算法·visual studio
澈2073 分钟前
排序算法入门:冒泡、选择、插入排序详解
数据结构·算法·排序算法
6Hzlia6 分钟前
【Hot 100 刷题计划】 LeetCode 152. 乘积最大子数组 | C++ 动态规划 (绝妙 swap 翻转技巧)
c++·leetcode·动态规划
smj2302_796826527 分钟前
解决leetcode第3901题好子序列查询
python·算法·leetcode
_深海凉_9 分钟前
LeetCode热题100-每日温度
算法·leetcode·职场和发展
迷你可可小生11 分钟前
面经学习(二)
学习·算法
John.Lewis12 分钟前
C++加餐课-二叉树:进阶算法
数据结构·c++·算法
郝学胜-神的一滴21 分钟前
ReLU激活函数全解析:从原理到实战,解锁深度学习核心激活单元
人工智能·pytorch·python·深度学习·算法
AGV算法笔记26 分钟前
最新感知算法论文分析:RaCFormer 如何提升雷达相机 3D 目标检测性能?
数码相机·算法·3d·自动驾驶·机器人视觉·3d目标检测·感知算法
脱氧核糖核酸__27 分钟前
LeetCode热题100——54.螺旋矩阵(题解+答案+要点)
c++·算法·leetcode·矩阵