100道题里的中等和简单级别的题基本都做完了,现在困难级别的来了。看完题目尝试暴力解来着,但是却觉得代码越写越复杂,越来越麻烦。果然困难题目难就难在这个分情况分类讨论了,真是分类分类,越分越“累”。那就来想各种可能的结果吧。
解法一:回溯
1、当s为空且p为空 —> 返回 true,否则返回 false
2、当p[1]!='*',且s[0]==p[0] || p[0]=='.' —> 对p[1:]和s[1:]进行匹配,否则返回 false
3、当p[1]==‘*’ —> 循环,每一次循环都对s[0:]和p[2:]或者在满足s[0]==p[0] || p[0]=='.'条件的情况下,令s[1:]和p进行匹配,二者有任一匹配,返回true,否则返回 false.
各种情况要进行分类,还要考虑各种细节的可能,感受到难度了,要学会顺着机器的思路,思考各种可能的情况,并将这些情况归类,分开依次解决。
func isMatch(s string, p string) bool {
return SubMatch([]rune(s), []rune(p))
}
func SubMatch(s, p []rune) bool {
if len(p)==0 { return len(s)==0 }
if len(p)>1 && p[1]=='*'{
return SubMatch(s, p[2:]) || (len(s)!=0 && (s[0]==p[0]||p[0]=='.') && SubMatch(s[1:], p))
}else{
return len(s)!=0 && (s[0]==p[0]||p[0]=='.') && SubMatch(s[1:], p[1:])
}
}