力扣1218. 最长定差子序列

动态规划

  • 思路:
    • 定义 dp[v] 是值为 v 结尾的最长等差子序列个数;
    • 状态转移方程为:
      • v 上一个序列值为 v - d,即 dp[v] = dp[v - d] + 1;
    • 通过遍历序列,动态规划找到所有序列元素的最长等差数列的个数,结果为其中最大的值;
    • 因为下标不是连续的,可以使用哈希表来存储 dp;
class Solution {
public:
    int longestSubsequence(vector<int>& arr, int difference) {
        int ans = 0;
        std::unordered_map<int, int> dp;
        for (int v : arr) {
            dp[v] = dp[v - difference] + 1;
            ans = std::max(ans, dp[v]);
        }

        return ans;
    }
};

————————————————————————————————

相关推荐

  1. leetcode 1218.序列

    2024-01-25 07:28:04       16 阅读
  2. 公共序列

    2024-01-25 07:28:04       16 阅读
  3. 300. 递增序列 python AC

    2024-01-25 07:28:04       12 阅读
  4. 128.连续序列

    2024-01-25 07:28:04       31 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-25 07:28:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-25 07:28:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-25 07:28:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-25 07:28:04       20 阅读

热门阅读

  1. 深度学习-Pytorch数据集构造和分批加载

    2024-01-25 07:28:04       33 阅读
  2. 【自然语言处理】【深度学习】NLP中的N-gram理解

    2024-01-25 07:28:04       34 阅读
  3. xml与json的区别

    2024-01-25 07:28:04       35 阅读
  4. 算法训练营Day50(动态规划11)

    2024-01-25 07:28:04       41 阅读
  5. 算法第10天|232.用栈实现队列225. 用队列实现栈

    2024-01-25 07:28:04       35 阅读
  6. 不会有人上台阶摔倒吧 3476:【例86.1】 上台阶

    2024-01-25 07:28:04       33 阅读
  7. 【ESP32】Ubuntu2004搭建espressif

    2024-01-25 07:28:04       34 阅读
  8. C++拾遗(三) 引用

    2024-01-25 07:28:04       28 阅读
  9. 2024/1/24 图的基本应用

    2024-01-25 07:28:04       36 阅读