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

关于动态规划【力扣718.最长重复子数组的思考】

1、为什么dp数组要定义为二维数组?

// dp数组定义为二维是因为最长重复子数组的长度会受到两个东西的影响:1、nums1数组的元素值;2、nums2数组的元素值。

// 如果nums1和nums2在某个地方的值一样,连续下去的值也一样,就会影响重复的长度。

// 所以dp数组定义为二维

(dp数组的定义,如下图所示)

2、为什么dp数组的定义有1001?

// 因为题目的提示有提到nums1和nums2的长度不超过1001

(二维数组的定义用的是C++语法)

3、为什么dp[i][j]要表示以数组下标i-1结尾的nums1数组和以数组下标j-1为结尾的...而不是以数组下标i结尾的nums1数组和以数组下标j为结尾的...?

// 是为了方便后续的数组初始化

// 如果dp[i][j]表示以数组下标i结尾的nums1数组和以数组下标j为结尾的最长重复子数组长度为dp[i][j],那么在初始化二维数组的第一行dp[0][j]和第一列dp[i][0]的时候,要单独用两次for循环去计算,如果dp[0][0]和dp[0][j]相等的时候把dp[0][j]赋值为1,表示重复的长度为1;如果dp[0][0]和dp[i][0]相等的时候把dp[i][0]赋值为1,表示重复的长度为1。

// 但是如果用dp[i][j]表示以数组下标i-1结尾的nums1数组和以数组下标j-1为结尾的最长重复子数组长度为dp[i][j],那么在初始化二维数组的第一行dp[0][j]和第一列dp[i][0]的时候,就直接交给递推公式了

// 所以这里dp[i][j]要表示以数组下标i-1结尾的nums1数组和以数组下标j-1为结尾的...(省略号处为最长重复子数组长度为dp[i][j])...

http://www.jsqmd.com/news/1117305/

相关文章:

  • 2026学术神器榜!好用的AI智能降重工具实测,效率直接拉满!
  • 终极PubMed文献批量下载指南:5分钟搞定100篇文献的免费神器
  • AI免费背后的商业逻辑:算力租用与数据炼金模式对比
  • 新手网络安全入门:YAKIT与Nuclei Templates实战漏洞挖掘指南
  • 终极解决方案:为苹果触控板实现Windows原生精准触控体验
  • 计算机Java毕设实战-基于 SpringBoot 的智慧田园农事服务管理系统的设计与实现 农村田园用地分配与运维管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 揭秘openEuler内核文档库:一站式掌握内核特性、会议记录与技术分享的终极指南
  • FPGA上CNN推理优化的数据速率感知技术
  • 临床试验中的AI伦理护栏:可追溯、可审计、可问责的LLM落地实践
  • 3步解锁专业文档排版:Liberation Fonts完全指南 [特殊字符]
  • 猫抓Cat-Catch终极指南:三步轻松捕获网页视频音频资源
  • 当机器人成为情感寄托:人形伴侣的技术落地与伦理边界思考
  • WebcamJS:HTML5摄像头图像捕捉库的现代化实现方案
  • Path of Building:流放之路角色构建的离线计算解决方案
  • GZMB+T细胞与凋亡肿瘤细胞相邻意味着什么?组织原位空间蛋白组学带您解析
  • 洛雪音乐音源终极指南:一站式解决全网音乐聚合难题
  • 如何用开源工具在10分钟内制作专业级H5页面?h5maker告诉你答案
  • ChanlunX缠论通达信插件:5分钟快速掌握专业缠论分析的终极指南
  • PHP商业项目安全授权与代码保护实战:从机制设计到逆向防护
  • AI时代程序员如何利用AI工具提升核心竞争力与工作效率
  • 植被参数光学遥感反演方法(Python)及遥感与生态模型数据同化算法
  • STC3115电池监控芯片与STM32F745VG的高精度电池管理系统设计
  • Navicat无限试用终极指南:3种方法彻底解决macOS数据库工具试用期限制
  • WidescreenFixesPack宽屏修复解决方案配置指南
  • Visual Syslog Server:Windows平台最直观的Syslog日志监控终极指南
  • Windows 11终极优化指南:用Win11Debloat让系统更快更干净
  • Spring Boot整合Redis:性能优化与实战指南
  • TIDAL无损音乐下载终极指南:如何快速获取24-bit高解析度音频
  • PIC32MZ与IS31FL3731打造高效LED矩阵控制方案
  • STM32与TI降压转换器的嵌入式电源系统设计