当前位置: 首页 > news >正文

diy在线定制网站系统网站建设c云世家宋南南

diy在线定制网站系统,网站建设c云世家宋南南,网站seo优化如何做,响应式建网站目录 ​编辑 一,最长定差子序列 1.题目 2,题目接口 3,解题思路及其代码 一,最长定差子序列 1.题目 给你一个整数数组 arr 和一个整数 difference,请你找出并返回 arr 中最长等差子序列的长度,该子序列…

目录

​编辑

一,最长定差子序列

1.题目

2,题目接口

 3,解题思路及其代码


一,最长定差子序列

1.题目

给你一个整数数组 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]。

2,题目接口

class Solution {
public:int longestSubsequence(vector<int>& arr, int difference) {}
};

 3,解题思路及其代码

1.状态转移方程:    

这道题要我们求的是最长定差子序列问题,不再是最长子序列。这里的关键便是定差,也就是说在我们知道差以后我们便可以知道第2个数的值。我们的dp[i] 表示为以i位置为结尾的最长等差子序列。

 2.初始化:

 当我们的每个nums[i]单独构成一个子序列时长度为1,所以我们初始化时边初始化为1即可。

在明确好这些后便可以写出如下代码:

class Solution {
public:int longestSubsequence(vector<int>& arr, int difference) {int n = arr.size();vector<int>dp(n,1);int Maxlenth = 1;for(int i = 0;i<n;i++){int num = arr[i]+difference;//找定差for( int j = i+1;j<n;j++){if(arr[j] == num){dp[j] = dp[i]+1;}}Maxlenth = max(Maxlenth,dp[i]);//每次都要更新一下最大值}return Maxlenth;}
};

但是,这个代码是过不了的。因为这个代码的时间复杂度为O(n^2)。所以我们要对这个代码做一些优化。优化的秘诀便是hash表:unordered_map。改进思路如下:

1.先创建一个hash表。

2.将arr里面的所有元素和元素的对应下标放到hash表中构成映射,arr[i]作key,下标作value。

现在改进代码如下:

class Solution {
public:int longestSubsequence(vector<int>& arr, int difference) {unordered_map<int,int> hash;//在hash表里做dpint n = arr.size();int Max = 1;hash[arr[0]] = 1;for(int i = 1;i<n;i++){hash[arr[i]] = hash[arr[i]-difference]+1;//如果arr[i]-difference那也会访问最后一个arr[i]-difference的值。因为hash的底层插入是头插Max = max(Max,hash[arr[i]]);}return Max;}
};

提交:过啦!!!

http://www.yayakq.cn/news/359309/

相关文章:

  • 网站产品展示赚钱平台
  • 自己做付费网站江苏恒健建设集团有限公司网站
  • 网站后台编辑框不显示网站设计师对应的专业
  • 龙岗模板网站建设红桥集团网站建设
  • 新能源网站开发济南济南网站建设网站建设
  • 初中学习网站大全免费wordpress 调用文章作者
  • 阳江做网站的公司南京网站设计公司大全
  • 广州网站建设公司推荐写作网站云
  • 爱站关键词挖掘工具网站建设东莞老铁博客
  • 网站开发的论文参考文献wordpress怎么设置关键字
  • 有没有像一起做网店做男装的网站网站风格类型是
  • 网站定制开发建设东莞公司注册价格
  • 网站开发包含网站维护吗wordpress 主题应用
  • 商业网站开发模式做网站的法律
  • 东莞网站建设怎么收费h5 php mysql网站开发
  • 自己弄公司网站网站建设技术服务
  • 学网站建设培训班wordpress hexo
  • 去国外做外卖网站做网站商城
  • 网站后台程序开发自媒体平台app
  • 搭建网站平台网站地图 用户体验
  • 企业网站建设递进发展趋势如何把代码放在网站首页教程
  • 英语培训网站源码别人网站的字体
  • 在酒吧里做那个视频网站wordpress搭建博客视频教程
  • flash 企业网站 源码wordpress 免费主题
  • 网页游戏网站电影做建网站
  • 云南城市建设官方网站长沙seo步骤
  • 做淘宝网站目的是什么公司做网站还是做app
  • 现在个人做网站还能盈利吗非法网站开发是什么意思
  • 企业网站建设费怎么入账毕设做桌面端还是网站
  • 做100个网站效果图网站竞价推广都有哪些