public class Solution {
public boolean isMatch(String s, String p) {
int m = s.length(), n = p.length();
char[] sc = s.toCharArray();
char[] pc = p.toCharArray();
boolean[][] dp = new boolean[m + 1][n + 1];
dp[0][0] = true;
for(int j = 1; j < n + 1; j++){
if(pc[j - 1] == '*') dp[0][j] = dp[0][j - 1];
}
for(int i = 1; i < m + 1; i++){
for(int j = 1; j < n + 1; j++){
if(pc[j - 1] == sc[i - 1] || pc[j - 1] == '?'){
dp[i][j] = dp[i - 1][j - 1];
} else if(pc[j - 1] == '*'){
dp[i][j] = dp[i - 1][j] || dp[i][j - 1];
} else {
dp[i][j] = false;
}
}
}
return dp[m][n];
}
}
空间优化
public class Solution {
public boolean isMatch(String s, String p) {
/**
* 这是看到论坛上的人用DP的思想实现的
* 本人没有实现,用递归写虽然正确,但是TLE
* 这一题我也没有彻底看懂本代码,只能先写到这里,以后再来学习
*/
int m = s.length(), n = p.length();
int count = 0;//*的个数
for (int i = 0; i < n; i++) {
if (p.charAt(i) == '*')
count++;//统计*的个数
}
if (count==0 && m != n)
return false;//如果没有*且m!=n,肯定不匹配
else if (n - count > m)
return false;//如果不是*的个数>m,则相等于没有*还是大于m,不匹配
boolean[] match = new boolean[m+1];//默认全为false
match[0] = true;//第一个设为true
for (int i = 0; i < n; i++) {
if (p.charAt(i) == '*') {//如果为*,则s对应的之后所有数据默认匹配
for (int j = 0; j < m; j++) {
match[j+1] = match[j] || match[j+1];
}
} else {//如果不为*,则用最后一位匹配
for (int j = m-1; j >= 0; j--) {
match[j+1] = (p.charAt(i) == '?' || p.charAt(i) == s.charAt(j)) && match[j];
}
match[0] = false;
}
}
return match[m];
}
}