没有思路,直接看的Solution。
思想:
一、 迭代法
假设s="ABCDE......",p="abcde......"
从s、p两字符串首字符进行比对,根据p第二个字符b是否等于‘*’分别进行处理。
(1)若b=‘*’,p="a*cde......",则a的出现次数为0~n
(1.1)若s与p首字符不同(A!=a),a的出现次数必为0,此时忽略“a*”直接对后面字符进行匹配就可以了,即调用isMatch(s,p.substring(2))
(1.2)若s与p首字符相同(A=a),则a的出现次数可能为0也可能大于0
(1.2.1)若a的出现次数为0,同(1.1)
(1.2.2)若a的出现次数大于0,此时应逐一判断s之后几个字符BCDE......是否等于a,即调用
isMatch(s.substring(1),p)
(2)若b!=‘*’,则判断s和p首字符A、a是否相同,若不相同则返回false,若相同则进一步判断之后的字符串
s.substring(1)和p.substring(1)
二、 动态规划
1. 与迭代法总体思路一致,增加布尔型数组 memo[i][j] 记录s,p字符串中下标ij对应的字符是否曾经比较过、是否匹配成功。
若之前已比较过,则根据memo直接返回是否匹配成功的结果即可,避免再次进行重复比较。
2. 在 1. 的基础上从字符串最后一个字符开始记录memo[i][j],这样可以保证计算memo[i][j]时,memo[i+...][j+...]都已经被赋值过了,省去了迭代调用函数的过程。
常用方法总结:
String.substring(begin)表示截取范围从begin下标到字符串最后的子字符串。
若String.length()=1,String.substring(1)="",String.substring(2)会抛出异常。