LeetCode 1027——最长等差数列

阅读目录

    • 1. 题目
    • 2. 解题思路
    • 3. 代码实现

1. 题目

2. 解题思路

假设我们以 f[d][nums[i]]表示以 nums[i] 为结尾元素间距为 d 的等差数列的最大长度,那么,如果 nums[i]-d 也存在于 nums 数组中,则有:

f [ d ] [ n u m s [ i ] ] = f [ d ] [ n u m s [ i ] − d ] + 1 f[d][nums[i]]=f[d][nums[i]-d]+1 f[d][nums[i]]=f[d][nums[i]d]+1

否则, f [ d ] [ n u m s [ i ] ] = 1 f[d][nums[i]]=1 f[d][nums[i]]=1

d的取值范围为 [ − ( m a x − m i n ) , + ( m a x − m i n ) ] [-(max-min), +(max-min)] [(maxmin),+(maxmin)]。因为 nums[i]-d 要位于 nums[i] 的前面,所以,针对每一个 d ,我们初始化所有元素为 -1,然后从前往后开始遍历数组,根据上面的公式依次更新 f,其中最大的数值即为所求。

时间复杂度为 O ( d ∗ n u m s . s i z e ( ) ) O(d*nums.size()) O(dnums.size()),空间复杂度为 O ( n u m s . s i z e ( ) ) O(nums.size()) O(nums.size())

3. 代码实现

于是,我开始实现了第一版代码,完全就照着上面的解题思路来写。

class Solution {
public:int longestArithSeqLength(vector<int>& nums) {map<int, map<int, int> > dp;int max_value = 0;int min_value = 500;map<int, int> init_dp;for (size_t i = 0; i < nums.size(); ++i){max_value = max(max_value, nums[i]);min_value = min(min_value, nums[i]);init_dp[nums[i]] = -1;}int diff = max_value - min_value;int ret = 1;for (int d = -diff; d <= diff; ++d) {dp[d] = init_dp;dp[d][nums[0]] = 1;for (size_t i = 1; i < nums.size(); ++i) {if (dp[d].count(nums[i]-d) == 0) {dp[d][nums[i]] = 1;continue;}if (dp[d][nums[i]-d] != -1) {dp[d][nums[i]] = dp[d][nums[i]-d] + 1;ret = max(ret, dp[d][nums[i]]);}else {dp[d][nums[i]] = 1;}}}return ret;}
};

很可惜,没有通过全部测试用例,超时了。

超出时间限制 53 / 65 个通过的测试用例

首先,这里的 dp就是充当哈希表的作用,不需要有序,没有必要用 map,我改成了 unordered_map后,通过了,但是执行用时和消耗内存都排在了末尾。

查看双层 for 循环,针对每一个d,我们其实可以都用同一个哈希表,所以代码作如下修改:

class Solution {
public:int longestArithSeqLength(vector<int>& nums) {int max_value = 0;int min_value = 500;unordered_map<int, int> init_dp;for (size_t i = 0; i < nums.size(); ++i){max_value = max(max_value, nums[i]);min_value = min(min_value, nums[i]);init_dp[nums[i]] = -1;}int diff = max_value - min_value;int ret = 1;for (int d = -diff; d <= diff; ++d) {unordered_map<int, int> dp = init_dp; // 这里每次都用同一个即可dp[nums[0]] = 1;for (size_t i = 1; i < nums.size(); ++i) {if (dp.count(nums[i]-d) == 0) {dp[nums[i]] = 1;continue;}if (dp[nums[i]-d] != -1) {dp[nums[i]] = dp[nums[i]-d] + 1;ret = max(ret, dp[nums[i]]);}else {dp[nums[i]] = 1;}}}return ret;}
};

这样,速度和内存都有所提升,但提升得也非常有限。继续思考,题目中给出了 0 <= nums[i] <= 500 的限制条件,所以 n u m s [ i ] − d ∈ [ 0 , 500 ] nums[i]-d\in[0,500] nums[i]d[0,500],如果不在这个范围,肯定是无效的。所以,dp直接就可以用一个大小为 501 的数组来代替了,数组的下标就可以作为索引。

class Solution {
public:int longestArithSeqLength(vector<int>& nums) {int max_value = 0;int min_value = 500;for (size_t i = 0; i < nums.size(); ++i){max_value = max(max_value, nums[i]);min_value = min(min_value, nums[i]);}int diff = max_value - min_value;int ret = 1;for (int d = -diff; d <= diff; ++d) {vector<int> dp(501, -1);dp[nums[0]] = 1;for (size_t i = 1; i < nums.size(); ++i) {if (nums[i]-d < 0 || nums[i]-d > 500) {dp[nums[i]] = 1;continue;}if (dp[nums[i]-d] != -1) {dp[nums[i]] = dp[nums[i]-d] + 1;ret = max(ret, dp[nums[i]]);}else {dp[nums[i]] = 1;}}}return ret;}
};

class Solution:def longestArithSeqLength(self, nums: List[int]) -> int:max_value = max(nums)min_value = min(nums)diff = max_value - min_valueret = 1for d in range(-diff, diff+1):dp = [-1] * 501dp[nums[0]] = 1for i in range(1, len(nums)):if 0 <= nums[i] - d <= 500:dp[nums[i]] = max(dp[nums[i]-d]+1, 1)ret = max(ret, dp[nums[i]])else:dp[nums[i]] = 1return ret

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NSS [SWPUCTF 2022 新生赛]Power!

NSS [SWPUCTF 2022 新生赛]Power! 开题。 随便传一个111&#xff0c;后端进行了一个文件包含操作。 输入index.php&#xff0c;回显了一个不可显示图片。 有点小蒙蔽的&#xff0c;一般这种情况就源码&#xff0c;抓包&#xff0c;扫描。源码里面果然有货。 base解码后是index…

了解Spring:Java开发的利器

Spring是一款开源的轻量级Java开发框架&#xff0c;旨在提高开发人员的效率和系统的可维护性。本文将介绍Spring的基本概念、使用优势、设计模式以及与Spring MVC和Spring Boot的关联。 什么是Spring&#xff1f; Spring是一款开源的轻量级Java开发框架&#xff0c;它由多个模…

JAVA----进程

进程(process) 目录 进程(process)1. 进程--即一个**跑起来**的运用程序2. 进程 可视为是操作系统进行资源分配的基本单位3. 在操作系统中,通常使用称为 PCB 这样的结构体来描述进程的.4. PCB5. 文件描述符(重点)6. 进程调度(关键重点)1. PCB 提供了几个属性,支持 进程调度1. 状…

2024常用接口抓包以及接口测试工具总结【建议收藏】

接口 统称为API&#xff0c;程序与程序之间的对接、交接。 接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点&#xff0c;主要是为了检验不同组件&#xff08;模块&#xff09;之间数据的传递是否正确&#xff0c;同时接口测试还要测试当前系统与第三方…

SQLiteC/C++接口详细介绍sqlite3_stmt类(七)

返回&#xff1a;SQLite—系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;六&#xff09; 下一篇&#xff1a; 无 22、sqlite3_column_database_name 用于返回结果集中指定列的数据库名称。如果结果集是由多个Join操作产生的&#xff0c;…

LabVIEW电动汽车直流充电桩监控系统

LabVIEW电动汽车直流充电桩监控系统 随着电动汽车的普及&#xff0c;充电桩的安全运行成为重要议题。通过集成传感器监测、单片机技术与LabVIEW开发平台&#xff0c;设计了一套电动汽车直流充电桩监控系统&#xff0c;能实时监测充电桩的温度、电压和电流&#xff0c;并进行数…

Tether CEO力挺波场TRON,直言其在一定程度实现了惠普金融

近期,加密媒体Bankless对Tether CEO Paolo Ardoino进行了深度专访。在专访中,Tether CEO Paolo Ardoino详细且深入地向听众们介绍了USDT,并对波场TRON的成就给予了高度认可。他更是直接表示,“我们不应该讨厌波场TRON,更应该换位思考站在其他人的角度考虑,尤其是那些无法负担起…

C++实现FFmpeg音视频实时拉流并播放

1.准备工作: 下载rtsp流媒体服务器rtsp-simple-server,安装go开发环境并编译 编译好后启动流媒体服务器 准备一个要推流的mp4视频文件,如db.mp4 使用ffmpeg开始推流 推流命令: ffmpeg -re -stream_loop -1 -i db.mp4 -c copy -rtsp_transport tcp -f rtsp rtsp://192.168.16…

【网络安全】这份近 200 页应急响应文档,帮助了不少安全逆子

前言 成为伟大黑客的关键在于做自己喜爱的事&#xff0c;要把一件事情做好&#xff0c;你必须热爱它。所以只要你能坚持对安全技术的热爱&#xff0c;到了这种程度&#xff0c;你就会做得更好。 本文档注重理论与实战结合&#xff0c;不仅提供关键源代码供读者快速实践&#x…

2.1 Windows安装Python

Windows安装Python&#xff08;图解&#xff09; 在 Windows 上安装 Python和安装普通软件一样简单&#xff0c;下载安装包以后猛击“下一步”即可。 Python 安装包下载地址&#xff1a;https://www.python.org/downloads/ 打开该链接&#xff0c;可以看到有两个版本的 Pyth…

AD20如何整体修改元器件标号?

1 2这里可以设置元器件标号方向 3更新 4点击前两个选项&#xff08;生成&#xff0c;执行&#xff09;即可

蓝桥杯刷题-串的处理

串的处理 代码 s input().split() l_new [] for i in s:i list(i)new""for j in range(len(i)-1): # 遍历newi[j]if i[j].isdigit() and i[j1].isalpha(): # 在字母和数字之间添加“_”new_if i[j].isalpha() and i[j1].isdigit(): # 同上new_newi[-1]l_new.appe…

用这几个工具搭建内容管理平台,企业工作效率翻倍!

在当今这个信息爆炸的数字时代&#xff0c;良好的内容管理变得尤为重要。无论你是一个大型企业&#xff0c;还是一个小型创业公司&#xff0c;一个高效的内容管理系统&#xff08;CMS&#xff09;都能够帮助你有条理地规划、创建、发布和优化你的内容。如果你正在寻找一款出色的…

@arco.design radioGroup 组件手写 beforeChange 方法

官方是没有提供 beforeChange 事件的&#xff0c;只能自己写一个 子组件&#xff08;CustomRadioGroup&#xff09; <template><a-radio-group :model-value"modelValue" change"onRadioChange"><a-radio v-for"item in list" …

第13篇:4线-2线优先编码器

Q&#xff1a;上一篇我们实现的4线-2线普通编码器在实际应用中会存在一个问题&#xff1a;如果中有2个或2个以上的取值同时为1&#xff0c;输出编码会出现混乱。本篇我们再来学习设计4线-2线优先编码器解决这个问题。 A&#xff1a;基本原理&#xff1a;规定操作先后顺序&…

Protocol Buffers设计要点

概述 一种开源跨平台的序列化结构化数据的协议。可用于存储数据或在网络上进行数据通信。它提供了用于描述数据结构的接口描述语言&#xff08;IDL&#xff09;&#xff0c;也提供了根据 IDL 产生代码的程序工具。Protocol Buffers的设计目标是简单和性能&#xff0c;所以与 XM…

路径问题总结

257二叉树的所有路径 257二叉树的所有路径 class Solution {public List<String> binaryTreePaths(TreeNode root) {List<String> ans new ArrayList<>();dfs(root,"",ans);return ans;}private void dfs(TreeNode root,String path,List<St…

计算机网络:物理层中的数字传输系统全景概览解析

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

使用Python制作一个批量查询搜索排名的SEO免费工具

搭建背景 最近工作中需要用上 Google SEO&#xff08;搜索引擎优化&#xff09;&#xff0c;有了解过的朋友们应该都知道SEO必不可少的工作之一就是查询关键词的搜索排名。关键词少的时候可以一个一个去查没什么问题&#xff0c;但是到了后期&#xff0c;一个网站都有几百上千…

【Unity】捕捉PC桌面的插件

【背景】 之前介绍了如何用一款名为uWindowCapture的Unity免费插件在Unity的Canvas上展示PC桌面。经过一段时间的使用,本篇继续分享此插件的一些功能和限制。 在此感谢作者Hecomi。 【特征和限制】 一般局域网络环境只能最多达到15帧的帧率,所以别幻想用来窜流游戏或者看电…