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

集成wamp访问域名打开tp做的网站卡一卡二卡三入口2021

集成wamp访问域名打开tp做的网站,卡一卡二卡三入口2021,永久免费的网站空间,南京网站开发南京乐识赞想要精通算法和SQL的成长之路 - 最长等差数列 前言一. 最长等差数列 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 最长等差数列 原题链接 思路: 我们假设dp[i][j] 为:以num[i]为结尾,以j为公差的最长等差子序列的长度。由此可知&a…

想要精通算法和SQL的成长之路 - 最长等差数列

  • 前言
  • 一. 最长等差数列

前言

想要精通算法和SQL的成长之路 - 系列导航

一. 最长等差数列

原题链接
在这里插入图片描述
在这里插入图片描述

思路:

  1. 我们假设dp[i][j] 为:以num[i]为结尾,以j为公差的最长等差子序列的长度。由此可知,我们的代码存在2个循环。
  2. 外层循环,针对nums的每一个元素(下标为i),将其视为最长等差子序列的结尾元素。
  3. 内层循环,针对[0,i)这个范围的元素,求得每种公差的最长等差子序列长度。此时二层循环下标索引为k,计算出每个元素和当前num[i]之间的公差:j
  4. 即有:dp[i][j] = Max(dp[i][j], dp[k][j] + 1)
  5. 同时我们用一个全局变量res,不断地更新它的最大值即可。res = Math.max(res, dp[i][j]);

注意的点:

  1. 考虑到公差为负数的情况,那么结合题目本身,我们可以发现公差的范围是[-500,500],为了避免下标越界,我们统一把公差的值转为正数。即公差统一加上500,那么范围是[0,1000]。我们就可以初始化动态规划数组: int[][] dp = new int[nums.length][1001];
  2. 如果我们没有给数组的所有可能初始化为1(单个元素自身也可成为一个子数组,长度为1),我们只需要返回结果+1即可。

最终代码如下:

public class Test1027 {public int longestArithSeqLength(int[] nums) {int res = Integer.MIN_VALUE;int[][] dp = new int[nums.length][1001];for (int i = 1; i < nums.length; i++) {for (int k = 0; k < i; k++) {// 公差统一+500int j = nums[i] - nums[k] + 500;// 更新[0,i) 中,所有以 j 为公差 的最长子序列长度,同时更新dp[i][j]dp[i][j] = Math.max(dp[i][j], dp[k][j] + 1);// 更新最大值res = Math.max(res, dp[i][j]);}}return res + 1;}
}
http://www.hkea.cn/news/220082/

相关文章:

  • 厦门做网站seo的seo服务公司招聘
  • 安徽池州做企业网站百度搜索官方网站
  • 芜湖商城网站建设青岛百度快速优化排名
  • 我找伟宏篷布我做的事ko家的网站seoul怎么读
  • 即墨做网站优书网首页
  • 网站建设实践报告3000字放单平台
  • 中华人民共和国城乡住房建设厅网站seo技术外包
  • 网站做销售是斤么工作东莞网站营销推广
  • 做网站现在还行吗宁德市疫情
  • 响应式网站首页百度搜索资源
  • 工人找工作哪个网站好福州百度seo
  • 台湾做甜品的网站谷歌seo关键词排名优化
  • 织梦网站导入链接怎么做谷歌广告投放
  • 沈阳网站哪家公司做的好镇江关键字优化品牌
  • 台州本地做网站的做引流推广的平台600
  • 网站的导航用css怎么做网站外链查询
  • 青岛模版网站建设关键词优化按天计费
  • 高端网站建设服务器seo服务哪家好
  • 服装网站建设分析网站浏览器
  • 建站城企业邮箱怎么开通注册
  • html做动态网站cms
  • 一个网站建设需要多少钱百度seo排名优化公司
  • 网站做app的软件友博国际个人中心登录
  • 做网站用什么代码编写可口可乐软文营销案例
  • 宜昌网站建设哪家好厦门百度广告开户
  • 网站做二级域名外链
  • 网站建设服务费属于哪个大类电商seo搜索优化
  • 12380网站建设情况的报告网络seo首页
  • 个人如何在百度上做广告网站seo什么意思
  • java做网站编程合肥seo快排扣费