1. 题目
Implement regular expression matching with support for '.' and '*'.
'.' Matches any single character.
'*' Matches zero or more of the preceding element.
The matching should cover the entire input string (not partial).
The function prototype should be:
bool isMatch(const char s,const char p)
Some examples:
isMatch("aa","a") → false
isMatch("aa","aa") → true
isMatch("aaa","aa") → false
isMatch("aa","a*") → true
isMatch("aa",".*") → true
isMatch("ab",".*") → true
isMatch("aab","cab") → true
2. 思路
场景1:a*ab "aaab"
场景2:abac "ac"
用递归的方法来处理,对于x*,要处理有0到N个x被match下后剩下的递归匹配。
对于其他非x*的场景,直接匹配之后递归即可。
注意:当匹配串全部完成之后,如果模式串还有,查看一下剩下的模式串是不是可以匹配空字符串的即可,比如“abc*”的任意重复pair形式。
3. 代码
耗时:79ms
class Solution { public: bool isMatch(string s,string p) { return isMatch(s,p,0); } bool isMatch(const string& s,int i,const string& p,int j) { if (s.length() == i) { return p.length() == j || (p.length() > j+1 && p[j+1] == '*' && isMatch(s,i,j+2)); } if (p.length() > j+1 && p[j+1] == '*') { if (s[i] == p[j] || p[j] == '.') { return isMatch(s,i+1,j) || isMatch(s,j+2); } else { return isMatch(s,j+2); } } else { if (s[i] == p[j] || p[j] == '.') { return isMatch(s,j+1); } else { return false; } } } };