题目描述




动态规划组成部分一:确定状态

动态规划组成部分二:转移方程

动态规划组成部分三:初始条件和边界情况

动态规划组成部分四:计算顺序

Java代码实现
public boolean isMatch(String s, String p) {
int m = s.length();
int n = p.length();
char[] ch1 = s.toCharArray();
char[] ch2 = p.toCharArray();
boolean[][] f = new boolean[m + 1][n + 1];
f[0][0] = true;
for (int i = 0; i <= m; i++)
for (int j = 1; j <= n; j++) {
if ((ch2[j - 1] != '*') && (i > 0)) {
if (ch2[j - 1] == '?' || ch1[i - 1] == ch2[j - 1])
f[i][j] = f[i - 1][j - 1];
} else if (ch2[j - 1] == '*') {
f[i][j] = f[i][j - 1];
if (i > 0)
f[i][j] |= f[i - 1][j];
}
}
return f[m][n];
}

该博客探讨了动态规划在字符串匹配问题中的应用,详细解析了一个使用Java编写的动态规划解决方案。代码展示了如何通过确定状态、转移方程、初始条件和边界情况来解决字符串匹配问题。
7726

被折叠的 条评论
为什么被折叠?



