【题目描述】Implement wildcard pattern matching with support for’?‘and’’.
‘?’ Matches any single character.
'’ Matches any sequence of characters (including the empty sequence).
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”, "") → true
isMatch(“aa”, "a") → true
isMatch(“ab”, “?") → true
isMatch(“aab”, "ca*b”) → false
【解题思路】https://www.cnblogs.com/grandyang/p/4401196.html
【考查内容】字符串
class Solution {
public:
bool isMatch(string s, string p) {
int i = 0, j = 0, iStar = -1, jStar = -1;
while (i < s.size()) {
if (s[i] == p[j] || p[j] == '?') {
++i; ++j;
}else if (p[j] == '*') {
iStar = i;
jStar = j++;
} else if (iStar >= 0) {
i = ++iStar;
j = jStar + 1;
} else return false;
}
while (j < p.size() && p[j] == '*') ++j;
return j == p.size();
}
};