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

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

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

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

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

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

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

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

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

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

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

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

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

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

相关推荐
技术小黑1 小时前
CNN算法实战系列08 | ResNeXt-50算法实战与猴痘病识别
人工智能·算法·cnn
Full Stack Developme1 小时前
Java 漏斗算法 及应用场景
java·开发语言·算法
atunet2 小时前
关于稀疏图结构的高效存储与遍历算法设计的技术7
算法
ysa0510302 小时前
【并查集】判环,深搜
数据结构·c++·算法·深度优先
Jerry2 小时前
LeetCode 704. 二分查找
算法
Gp7HH6hrE2 小时前
P1118 [USACO06FEB] Backward Digit Sums G/S
算法·深度优先
AI科技星2 小时前
32维超复数流形中意识信息场与物质耦合的拓扑动力学
人工智能·学习·算法·数据挖掘·回归·乖乖数学·全域数学
YuK.W3 小时前
Leetcode100: 94.二叉树中序遍历、104.二叉树最大深度、226.翻转二叉树
java·算法·leetcode·二叉树
气泡音人声分离4 小时前
技术解析|均衡器(EQ)工作原理与实操指南:从频率拆分到听感优化
算法·均衡器·音频剪辑