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

网站建设打不开广州建站网络公司

网站建设打不开,广州建站网络公司,海南网站建设方案,北京网站建设app开发#x1f495;你可以说我贱#xff0c;但你不能说我的爱贱。#x1f495; 作者#xff1a;Mylvzi 文章主要内容#xff1a;算法系列–动态规划–子序列(2) 今天带来的是算法系列--动态规划--子序列(2),包含了关于子序列问题中较难的几道题目(尤其是通过二维状… 你可以说我贱但你不能说我的爱贱。 作者Mylvzi 文章主要内容算法系列–动态规划–子序列(2) 今天带来的是算法系列--动态规划--子序列(2),包含了关于子序列问题中较难的几道题目(尤其是通过二维状态表示来推导状态转移方程) 1.最⻓定差⼦序列 链接: https://leetcode.cn/problems/longest-arithmetic-subsequence-of-given-difference/description/ 分析: 状态表示:dp[i]:以i为结尾的,最长的定差子序列的长度状态转移方程:if(hash.contains(a - difference)) dp[i] dp[k] 1优化:由于要寻找a-difference与其对应的下标k,所以我们可以利用一个哈希表来建立数值与下标之间的映射关系 代码: class Solution {public int longestSubsequence(int[] arr, int difference) {MapInteger,Integer hash new HashMap();int ret 1;// 记录最值for(int a : arr) {hash.put(a,hash.getOrDefault(a-difference, 0 ) 1);// 将当前位置插入到哈希表中ret Math.max(ret,hash.get(a));// 更新最值}return ret;} }2.最⻓的斐波那契⼦序列的⻓度 链接: https://leetcode.cn/problems/length-of-longest-fibonacci-subsequence/ 分析: 代码: class Solution {public int lenLongestFibSubseq(int[] nums) {int n nums.length;int[][] dp new int[n][n];// 初始化为2for(int i 0; i n; i) {for(int j 0; j n; j) dp[i][j] 2;}MapInteger,Integer hash new HashMap();for(int i 0; i n; i) hash.put(nums[i], i);// 将数组中的值和下标存入到哈希表之中hash.put(nums[0],0);int ret 2;// 填表for(int j 1; j n; j) {for(int i 0; i j; i) {int a nums[j] - nums[i];// 得到前一个位置的数if(a nums[i] hash.containsKey(a)) {//必须包含 且下标在i之前dp[i][j] dp[hash.get(a)][i] 1;// 更新}ret Math.max(ret,dp[i][j]);// 更新最值}}return ret 3 ? 0 : ret;// 处理极端情况(无fib数列)} }3.最⻓等差数列 链接: https://leetcode.cn/problems/longest-arithmetic-subsequence/description/ 分析: 这道题笔者最开始经过分析,认为这道题和最长的斐波那契子序列的解法相同,同样的是利用固定两个数的方式来确定完整的等差数列,但是并未通过,反思如下: 最长的斐波那契子序列这道题目中,题目明确了整个序列是严格递增的,但是本题并没有这样的要求.这就加大了本题的难度,如果是严格递增的,就不需要考虑值重复的问题,但本题需要考虑,此时就需要使用key,下标数组这样的方式来保存值与下标之间的映射关系,在获取最长的长度时,我们需要的离倒数第二个数最近的元素的下标(此时的dp表中对应的长度是最长的),所以在得到nums[i] - nums[j]之后,还需要去便利整个下标数组,拿到最大的下标,进而获得最大的长度上述方式固然是一种解决方案,但是时间复杂度也很高,优化策略:一边dp,一边保存离nums[i]最近的值的下标如何实现上述策略呢?要想实现上述策略,需要我们在填表的时候采用固定倒数第二个数,枚举后一个数的方式,这样能保证我们获取到的a是离nums[i]最近的位置 代码: class Solution {public int longestArithSeqLength(int[] nums) {int n nums.length;int[][] dp new int[n][n];// 初始化为2for(int i 0; i n; i) {for(int j 0; j n; j) dp[i][j] 2;}MapInteger,Integer hash new HashMap();hash.put(nums[0],0);int ret 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.containsKey(a)) {//必须包含 且下标在i之前dp[i][j] dp[hash.get(a)][i] 1;// 更新}ret Math.max(ret,dp[i][j]);// 更新最值}hash.put(nums[i],i);}return ret;} }另一种状态表示: 上述需要固定两个数的原因在于无法通过一个数直接找到一个完整的等差序列,更本质的原因在于我们不知道公差究竟是多少,但是我们可以将i位置对应的所有公差都存入到dp表之内,这样就能枚举所有的d的情况,所以我们可以使用以i位置为结尾,公差为d的最长的等差序列的长度 class Solution {public int longestArithSeqLength(int[] nums) {int nnums.length;int[][] dpnew int[n][1001];int maxLen0;//保存结果for(int k1;kn;k){for(int j0;jk;j){int dnums[k]-nums[j]500;//统一加偏移量使下标非负dp[k][d]dp[j][d]1; //根据 d 去填充dp[k][d]maxLenMath.max(maxLen,dp[k][d]);//维护最大值}}return maxLen1;} }但是笔者觉得第二种写法并不是特别好,有点投机取巧之嫌(其实只要能做出来就好) 4.等差数列划分II - ⼦序列 链接: https://leetcode.cn/problems/arithmetic-slices-ii-subsequence/description/ 分析: 之前做过等差数列划分I,那道题是子数组,强调必须是连续的,但是本题是子序列,是可以不连续的如果做过上面的第二道题最长的等差序列,本题其实很容易想到思路,同样的,由于之定义一个状态无法表示确定状态,所以需要两个状态dp[i][j]:以i,j位置(i j)为结尾的所有等差数列的个数思路和最长的等差序列也是相似的,首先固定倒数第一个数,接着从0遍历第二个数,找到符合条件的值后,获得其对应的下标,进而获得dp表中的值一分析觉得这道题和最长的等差序列那道题很像,但是那道题只用保存最长的长度就行,这道题需要用一个数组保存相同值的所有下标,所以在哈希表中建立的映射关系应该是key,int[](笔者想到了这点,但是不知道怎么表示int[],导致此题没做出来,惭愧惭愧),实际上只要存储一个List就行,遍历的时候使用for each遍历即可 代码: class Solution {private int ret;// 返回值public int numberOfArithmeticSlices(int[] nums) {int n nums.length;int[][] dp new int[n][n];// 存放值与相同值的所有下标(下标应该是一个下标数组)MapLong,ListInteger hash new HashMap();for(int i 0; i n; i) {long tmp (long)nums[i];if(!hash.containsKey(tmp))hash.put(tmp,new ArrayListInteger());hash.get(tmp).add(i);}for(int j 2; j n; j) {for(int i 1; i j; i) {long a 2L * nums[i] - nums[j];if(hash.containsKey(a)) {// 遍历下标数组(注意相同的一个值的下标有多个,而我们要求出所有的等差序列的个数,所以所有的下标都要加上)for(int k : hash.get(a)) {if(k i) dp[i][j] (dp[k][i] 1);// 1表示的是 k,j,i三个数字组成一个新的等差数列else break;}}ret dp[i][j];// 计算当前位置的和}}return ret;} }
http://www.pierceye.com/news/831471/

相关文章:

  • 微信上可以做网站吗网页设计作业讲解
  • 长春好的做网站公司潍坊 网站
  • 做网站自己装服务器谷歌排名规则
  • 58.搜房等网站怎么做效果才好商贸公司企业简介模板
  • 中国最早做网站是谁卖网站怎样做
  • 张店专业网站优化哪家好书画工作室网站模板网站建设
  • 兰州网站制作怎么样青海哪家做网站的公司最大
  • 云龙湖旅游景区网站建设招标网站升级改版需要几天
  • 高端大气网络设计建设公司网站织梦模板沈阳模板建站哪家好
  • 郑州哪有做网站的高端网站建设与制作
  • 江阴网站网站建设蓝色 宽屏 网站 模板下载
  • 网站建设设计大作业重庆公共信息交易资源网
  • 做公司网站的多少钱公司建网站价格
  • 河间米各庄网站建设制作网站页面模板 建设中
  • wordpress首页添加站点统计小工具住房城乡建设部门门户网站
  • 网站建设在哪块做创业园网站建设
  • 郑州搭建网站公司互联网公司网站建设的目的
  • 响应式视频网站什么是权重高的网站
  • 做教育网站挣钱我的网站域名是什么
  • django 网站开发实例哪里可以检测胎儿性别
  • 刷排名凡搜网站宝微信5000人接推广费用
  • 网站优化外包服务专业网站建设服务商
  • 江西企业网站建设费用wordpress正在执行例行维护_请一分钟后回来.
  • 苏宁推客如何做网站创建一个网站的步骤
  • 优化网站广告优化东莞美食网站建设报价
  • 单页网站的营销定制应用软件有哪些
  • 如何建立一个网站详细步骤品牌建设可以从哪方面入手
  • 杨浦做网站福州网站公司
  • 厦门网站建设工程汽车网站正在建设中模板
  • 关于网站规划建设方案书怎么制作官网