Leetcode P72 Java使用动态规划思想
ideas
定义dp数组
我们首先定一个n+1和m+1的数组,至于为什么是n+1和m+1,是因为d p【0】【i】
d p【i】【0】所代表的是他们对应的字符串为null的情况。这个dp数组的定义就是 以word i-1 结尾 和word j-1结尾相同的的最少操作数量 。
int n = word1.length();
int m = word2.length();
//定义 以word i-1 结尾 和word j-1结尾相同的的最少操作数量
int[][] dp = new int[n+1][m+1];
初始化
这么做的原因,就是当word1为“”的时候,word2为“abc”的时候,word1增加3个元素可以成为word2.
//初始化
for (int i = 0; i <= n ; i++) {
dp[i][0] = i;
}
for (int i = 0; i <= m ; i++) {
dp[0][i] =i;
}
递归推倒
如果两个字符一致的话那就不用处理这个字符串,
if (word1.charAt(i-1) == word2.charAt(j-1)){
dp[i][j] = dp[i-1][j-1];
}
如果不想等那么就判断各种情况,如dp 「/i-1][j]+1代表不要或者增加word.charAt[i],相反就是不要或者增加word2.chatAt(i),当 dp[i-1] [j-1] +1就是进行替换的操作
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m ; j++) {
if (word1.charAt(i-1) == word2.charAt(j-1)){
dp[i][j] = dp[i-1][j-1];
}else{
dp[i][j] = Math.min(
dp[i-1][j]+1,
Math.min(
dp[i][j-1] +1,
dp[i-1][j-1] +1
)
);
}
}
}
code
class Solution {
public int minDistance(String word1, String word2) {
int n = word1.length();
int m = word2.length();
//定义 以word i-1 结尾 和word j-1结尾相同的的最少操作数量
int[][] dp = new int[n+1][m+1];
//初始化
for (int i = 0; i <= n ; i++) {
dp[i][0] = i;
}
for (int i = 0; i <= m ; i++) {
dp[0][i] =i;
}
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= m ; j++) {
if (word1.charAt(i-1) == word2.charAt(j-1)){
dp[i][j] = dp[i-1][j-1];
}else{
dp[i][j] = Math.min(
dp[i-1][j]+1,
Math.min(
dp[i][j-1] +1,
dp[i-1][j-1] +1
)
);
}
}
}
return dp[n][m];
}
}