动态规划9,最长定差子序列,最长斐波那契子序列长度,最长等差数列

news2024/11/26 8:24:18

如果还没有做过前面的题,建议先去尝试动态规划8

1218. 最长定差子序列

在这里插入图片描述

如果对之前的题比较熟悉的话,比较容易直接这样写,但是这样会超出时间限制:

在这里插入图片描述

所以我们要变成一次遍历,就得倒着推,就像这样:

在这里插入图片描述
使dp[i] 表示以 i 为结尾的最长等差子序列的长度。
然后我们通过使用哈希表来进行优化:

  1. unordered_map<int,int> hash; 对应的是 arr[i] 和 dp[i] ,相当于直接对哈希表进行动态规划
  2. 根据状态转移可以得到:hash[arr[i]] = hash[arr[i] - difference] + 1;
class Solution {
public:
    int longestSubsequence(vector<int>& arr, int difference) {
        unordered_map<int,int> hash;  //arr[i] -- dp[i]

        int ret = 0;
        for(int i = 0; i<arr.size(); i++)
        {
            hash[arr[i]] = hash[arr[i] - difference] + 1;
            ret = max(ret,hash[arr[i]]);
        }
        return ret;
    }
};

873. 最长的斐波那契子序列的长度

在这里插入图片描述
思路:

  1. 经验+题目要求
    dp[i]表示:以 i 位置为结尾的所有子序列中,最长的斐波那契子序列长度。error

这样只能固定最后一个数,这样是解决不了问题的。固定最后两个数可以知道前面所有数。
在这里插入图片描述
dp[i][j]表示:以 i 位置以及 j 位置为结尾的所有子序列中,最长的斐波那契子序列长度

  1. 状态转移方程
    在这里插入图片描述

  2. 初始化
    表里面所有值都初始化为2。

  3. 填表顺序
    从上往下

  4. 返回值
    dp表最大值ret,ret < 3 ? 0 : ret;

class Solution {
public:
    int lenLongestFibSubseq(vector<int>& arr) {
        int n = arr.size();
        //优化
        unordered_map<int,int> hash;
        for(int i = 0; i<n; i++) hash[arr[i]] = i;
        
        int ret = 0;
        vector<vector<int>> dp(n,vector<int>(n,2));
        for(int j = 2; j<n; j++)//固定最后一个位置
        {
            for(int i = 1; i<j; i++)//固定倒数第二个位置
            {
                int a = arr[j] - arr[i];
                if(hash.count(a) && a < arr[i])
                    dp[i][j] = dp[hash[a]][i] + 1;

                ret = max(ret,dp[i][j]);
            }
        }
        return ret < 3 ? 0 : ret;
    }
};

1027. 最长等差数列

在这里插入图片描述
思路:

  1. 经验+题目要求

dp[i][j]表示:以 i 位置以及 j 位置为结尾的所有子序列中,最长的斐波那契子序列长度

  1. 状态转移方程

在这里插入图片描述
对于优化:
我们选择第二种优化,因为效率更高。

  1. 初始化
    dp表里面所有值都初始化为2
  2. 填表顺序
    先固定倒数第二个数,然后枚举最后一个数。
class Solution {
public:
    int longestArithSeqLength(vector<int>& nums) {
        int n = nums.size();
        //优化
        unordered_map<int,int> hash;
        hash[nums[0]] = 0;
        //for(int i = 0; i<n; i++) hash[nums[i]] = i;
        
        int ret = 2;
        vector<vector<int>> dp(n,vector<int>(n,2));
        for(int i = 1; i<n; i++)//固定倒数第二个位置
        {
            for(int j = i+1; j<n; j++)//固定倒数第一个位置
            {
                int a = 2*nums[i] - nums[j];
                if(hash.count(a))
                    dp[i][j] = dp[hash[a]][i] + 1;

                ret = max(ret,dp[i][j]);
            }
            hash[nums[i]] = i;
        }
        return ret;
    }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1582604.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

windows server 2019 -DNS服务器搭建

前面是有关DNS的相关理论知识&#xff0c;懂了的可以直接跳到第五点。 说明一下&#xff1a;作为服务器ip最好固定下来&#xff0c;以DNS服务器为例子&#xff0c;如果客户机的填写DNS信息的之后&#xff0c;服务器的ip如果变动了的话&#xff0c;客户机都得跟着改&#xff0c…

HJ53 杨辉三角的变形(基础数学,生成数组不行,会越界,使用规律)

第一种方法&#xff1a; 生成杨辉三角的方法不行&#xff0c;会出现越界&#xff0c; 数组从[0][0]开始&#xff0c;i行j列 只看列 每一行的最右侧坐标为2*i,下坐标为 0&#xff0c; 0&#xff0c;1&#xff0c;2 0&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4 … …

学习:面向云备份提供商的 Solidigm 固态硬盘

SSD与HDD的区别 SSD和HDD之间的主要区别在于它们如何存储和传输数据。HDD有一个旋转盘片或磁盘&#xff0c;用于读取和写入数据。HDD的每GB初始价格通常低于SSD&#xff0c;这使其成为大型机构&#xff08;如金融机构、政府数据存储设施、高性能计算中心&#xff08;HPC&#…

OJ 栓奶牛【C】【Python】【二分算法】

题目 算法思路 要求的距离在最近木桩与最远木桩相隔距离到零之间&#xff0c;所以是二分法 先取一个中间值&#xff0c;看按照这个中间值可以栓多少奶牛&#xff0c;再与输入奶牛数比较&#xff0c;如果大于等于&#xff0c;则增大距离&#xff0c;注意这里等于也是增大距离…

NC报销单设置了转换模板后,没有生成临时凭证的排查。

NC报销单设置了转换模板后&#xff0c;没有生成临时凭证的排查 1、检查转换模板 2、检查交易类型 3、检查平台设置

RTK大气延迟建模精度分析

大气建模内插精度与终端定位性能密切相关。与流动站最近的参考站称为主参考站&#xff0c;此算例中&#xff0c;LXJS作为HF06的主参考站。图5分别给出了LXJS-HF06基线GPS时&#xff08;GPS time&#xff0c;GPST&#xff09; 00:00—24:00内GPS和BDS可视卫星的双差电离层延迟结…

App加固:不同类型和费用对比

文章目录 [TOC]引言应用程序加固是什么不同类型[App加固](https://www.ipaguard.com/)的费用对比基础加固高级加固云加固 白嫖的混淆加密工具](https://www.ipaguard.com/)-[ipaguard总结参考资料 引言 在当前移动应用市场中&#xff0c;安全性已经成为一个非常重要的话题。为…

2024年厨房大家电行业未来趋势分析(厨电行业线上分析报告)

如今&#xff0c;种种迹象都表明厨电行业正在向高端化、智能化、品质化做根本性的转变。不少厨房大家电的市场规模相较去年都有明显增长&#xff0c;其中也包括线上市场。 鲸参谋数据显示&#xff0c;从今年综合传统电商平台&#xff08;京东天猫淘宝&#xff09;1月至2月的数…

图片超分辨率重构实战——SRGAN

数据与代码链接见文末 论文地址:Photo-Realistic Single Image Super-Resolution Using a Generative Adversarial Network https://arxiv.org/abs/1609.04802v4 1.概述 通常来说,分辨率越低,图像越模糊,分辨率越高,图像越清晰,图像超分辨率重构就是将分辨率低的图像重…

怎么在手机中制作gif动图?用这个网站一键在线做

手机已经是我们日常生活中必不可少的日用品了&#xff0c;很多以前电脑上的软件现在在手机上也能操作了。我们想要在手机上制作一个gif动图还不想下载一些操作复杂的软件的时候&#xff0c;要怎么办呢&#xff1f;很简单&#xff0c;不用着急只要在手机浏览器上搜索专业的Gif制…

刷题之Leetcode54题(超级详细)

54. 螺旋矩阵54. 螺旋矩阵 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/spiral-matrix/submissions/521329682/ 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 示例 1&#xff1a; 输入…

搭建基于Hexo的个人博客

测试命令 hexo clean hexo g hexo s 上传命令 hexo clean hexo g hexo d 一、安装hexo 参考B站CodeSheep视频&#xff1a;手把手教你从0开始搭建自己的个人博客 |无坑版视频教程| hexo_哔哩哔哩_bilibili 安装node.js nodejs.org下载长期支持版 用管理员身份进入powersh…

全排列与全错排列

import java.util.Arrays; import java.util.Scanner; // 1:无需package // 2: 类名必须Main, 不可修改public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);//在此输入您的代码...long f10;long f21;long temp0;for (int i 3;…

提升数据安全与性能,掌握Helm一键部署MySQL 8.0主从技巧

在云原生应用开发中&#xff0c;数据库的高可用性和数据一致性是至关重要的。MySQL作为一种常用的关系型数据库&#xff0c;在云原生环境中的部署和管理也变得愈发重要。本教程将介绍如何使用Helm一键部署MySQL 8.0的主从复制架构&#xff0c;以实现数据库的高可用和数据备份。…

官网下载IDE插件并导入IDE

官网下载IDEA插件并导入IDEA 1. 下载插件2. 导入插件 1. 下载插件 地址&#xff1a;https://plugins.jetbrains.com/plugin/21068-codearts-snap/versions 说明&#xff1a;本次演示以IDEA软件为例 操作&#xff1a; 等待下载完成 2. 导入插件 点击File->setting->Pl…

白帽工具箱:初识Metasploit Framework(MSF)渗透测试框架

&#x1f31f;&#x1f30c; 欢迎来到知识与创意的殿堂 — 远见阁小民的世界&#xff01;&#x1f680; &#x1f31f;&#x1f9ed; 在这里&#xff0c;我们一起探索技术的奥秘&#xff0c;一起在知识的海洋中遨游。 &#x1f31f;&#x1f9ed; 在这里&#xff0c;每个错误都…

实验4 DHCP基础配置

实验4 DHCP基础配置 一、 原理描述二、 实验目的三、 实验内容四、 实验配置五、 实验步骤1.基本配置2.配置DHCPServer功能3.配置DHCP Client 一、 原理描述 动态主机配置协议 DHCP是一个局域网的网络协议&#xff0c;使用UDP协议工作&#xff0c;主要有两个用途&#xff1a;用…

昨天,“支付宝崩了”上热搜; 4 月编程语言排行榜:PHP 跌至历史最低点;老乡鸡 “开源” 了;微信 WCDB 迎来重大升级

0、支付宝崩了”上热搜&#xff0c;官方回应&#xff1a;短暂性访问不畅&#xff0c;已经快速恢复 昨日&#xff0c;有许多网友反映支付宝无法使用&#xff0c;用不了蚂蚁能量收集等功能&#xff0c;#支付宝崩了# 话题冲上微博热搜。 支付宝客服人员回应称&#xff0c;确实有系…

HJ102 字符统计(字符串,TreeMap,TreeMap是按照自身的顺序排序,比如数字的话,按照数字升序,ascII等。)

TreeMap是按照自身的顺序排序&#xff0c;比如数字的话&#xff0c;按照数字升序&#xff0c;ascII等。 import java.util.Scanner; import java.util.TreeMap;// 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main {public static void main(String[] arg…

全志V851se开发板TinyVision镜像制作快速启动教程

制作系统启动镜像​ 烧写系统​ 硬件&#xff1a;TinyVision主板 x1硬件&#xff1a;TypeC-SUB x1硬件&#xff1a;TF卡读卡器 x1硬件&#xff1a;8GB以上的 Micro TF卡 x1软件&#xff1a;Tina系统TF卡烧录工具: PhoenixCard-V2.8软件&#xff1a;TinaTF卡最小系统镜像&…