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

动态规划子序列问题系列一>等差序列划分II

题目: 

 


解析: 

1.状态表示: 

 


2.状态转移方程: 

这里注意有个优化

 


3.初始化: 

 


4.填表顺序: 

 


5.返回值: 

返回dp表总和 



代码: 

public int numberOfArithmeticSlices(int[] nums) {int n = nums.length;int sum = 0;int[][] dp = new int[n][n];//初始化哈希表Map<Long,List<Integer>> hash = new HashMap<>();for(int i = 0; i < n; i++){long tmp = (long)nums[i];//判断一下哈希表中是否存在tmp这个元素,不存在就new List,再存放放入List数组中if(!hash.containsKey(tmp))hash.put(tmp,new ArrayList<>()); //哈希表存不存在tmp元素,都就放入List数组中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 x : hash.get(a))if(x < i)dp[i][j] += dp[x][i] + 1;else break; //小优化sum += dp[i][j];    }return sum;      }

http://www.lryc.cn/news/510930.html

相关文章:

  • 48页PPT|2024智慧仓储解决方案解读
  • 低代码开源项目Joget的研究——Joget8社区版安装部署
  • upload-labs关卡记录15
  • 1.使用 Couchbase 数仓和 Temporal(一个分布式任务调度和编排框架)实现每 5 分钟的增量任务
  • matrix-breakout-2-morpheus
  • 农历节日倒计时:基于Python的公历与农历日期转换及节日查询小程序
  • 【RabbitMQ的死信队列】
  • 掌握软件工程基础:知识点全面解析【chap02】
  • 公路边坡安全监测中智能化+定制化+全面守护的应用方案
  • 闲谭Scala(3)--使用IDEA开发Scala
  • Go语言反射从入门到进阶
  • 【基于rust-wasm的前端页面转pdf组件和示例】
  • ARM64 Windows 10 IoT工控主板运行x86程序效率测试
  • 开放世界目标检测 Grounding DINO
  • easegen将教材批量生成可控ppt课件方案设计
  • 2002 - Can‘t connect to server on ‘192.168.1.XX‘ (36)
  • 【虚拟机网络拓扑记录】
  • 【单片机通讯协议】—— 常用的UART/I2C/SPI等通讯协议的基本原理与时序分析
  • Vue3 核心语法
  • LLaMA-Factory GLM4-9B-CHAT LoRA 指令微调实战
  • GTM023 W.H.Greub线性代数经典教材:Linear Algebra
  • 交换机与路由器的区别
  • springboot502基于WEB的牙科诊所管理系统(论文+源码)_kaic
  • soular使用教程
  • 纯div+css+js弹出窗
  • 一篇文章学会HTML
  • QGIS二次开发(插件开发)
  • Web防火墙和下一代防火墙的区别
  • Linux:alias别名永久有效
  • 【递归与回溯深度解析:经典题解精讲(中篇)】—— LeetCode