diff --git a/README.md b/README.md index 6765f4a..2a22380 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ | Current Status| Stats | | :------------: | :----------: | -| Total Problems | 172 | +| Total Problems | 173 | @@ -210,6 +210,8 @@ Include contains single header implementation of data structures and some algori | Problem | Solution | | :------------ | :----------: | | You are given a digit string (e.g "1234", "567" etc), provide all possible letter combinations we could generate from this digit string, based on the mapping we see on the telphone/mobile dialpad. If you have typed SMS in old style phones, you would know. For e.g. "1" is mapped to "abc", 2 is mapped to "def". You can refer to the image.. Note that order does not matter in result set.|[dialpad_combinations.cpp](backtracking_problems/dialpad_combinations.cpp)| +| Implement wildcard pattern maching with support for '?' & '*'. . Checkout examples in file for more details.|[wild_card_matching.cpp](backtracking_problems/wild_card_matching.cpp)| + ### Leet code Problems @@ -248,4 +250,3 @@ Include contains single header implementation of data structures and some algori | Count the number of islands in a grid. Given a grid representing 1 as land body, and 0 as water body, determine the number of islands (more details in problem comments)|[count_islands.cpp](leet_code_problems/count_islands.cpp)| | Find median from a data stream. Design a data structure that supports addNum to add a number to the stream, and findMedian to return the median of the current numbers seen so far. Also, if the count of numbers is even, return average of two middle elements, return median otherwise.|[median_stream.cpp](leet_code_problems/median_stream.cpp) | Remove the minimum number of invalid parentheses in order to make the input string valid. Return all possible results. Note: The input string may contain letters other than the parentheses ( and ) | [remove_invalid_parenthesis.cpp](leet_code_problems/remove_invalid_parenthesis.cpp)| - diff --git a/backtracking_problems/wild_card_matching.cpp b/backtracking_problems/wild_card_matching.cpp new file mode 100644 index 0000000..1531e40 --- /dev/null +++ b/backtracking_problems/wild_card_matching.cpp @@ -0,0 +1,84 @@ +/* + * Implement wildcard pattern maching with support for '?' & '*' + * '?' Matches any single character + * '*' Matches any sequence of character + * Source : Leetcode problem 44. + * + * Approach: + * + * Consider examples: + * is_match("aa", "a") false + * is_match("aa", "aaa") false + * is_match("aa", "?a") true + * is_match("aa", "?*") true + * is_match("aa", "*") true + * is_match("aa", "*a") true + * is_match("aa", "a*") true + * is_match("cabcab", "*ab") true + * + * Approach: + * Clearly, the '*' with multiple pattern matches makes this problem + * a little complicated, for example last case in the example. + * The second pattern of ab will give us the right answer. + * Therefore, we will have to try and match the same * with multiple + * patterns, and backtrack when we fail to match. + * For example: + * When we iterate source string and target pattern + * "cabcab" and "*ab" with i and j respectively, we will realize at + * i = 3 and j = 3 that we failed, at that time, we will have backtrack + * j back to position next to '*' i.e. j = 1, so that we can continue + * looking for further occurances of ab. + * Therefore, we will have to remember positions of '*' and reset + * iterator when we try to match the pattern. + */ + +#include +#include + + +bool is_match(const std::string& str, const std::string& pattern) +{ + int sLen = str.length(); + int pLen = pattern.length(); + int i = 0; + int j = 0; + int last_star_position = -1; + int last_match = -1; + while (i < sLen) { + if (j < pLen && (str[i] == pattern[j] || + pattern[j] == '?')) { + ++i; + ++j; + } + else if (j < pLen && pattern[j] == '*') { + last_star_position = j; + last_match = i; + j++; + } + else if (last_star_position != -1) { + j = last_star_position + 1; + last_match++; + i = last_match; + } + else return false; + } + + while (j < pLen && pattern[j] == '*') { + ++j; + } + return j == pLen; +} + +int main() +{ + std::string str{"cabcab"}; + std::string pattern{"*ab"}; + if (is_match(str, pattern)) { + std::cout << "'" << str << "'" + << " and '" << pattern << "'" << " are a match\n"; + } else { + std::cout << "'" << str << "'" + << " and '" << pattern << "'" << " are not a match\n"; + } + return 0; +} \ No newline at end of file