首页 > 其他 > 详细

Wildcard Matching

时间:2015-05-09 21:53:43      阅读:221      评论:0      收藏:0      [点我收藏+]

https://leetcode.com/problems/wildcard-matching/

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", "c*a*b") → false

解题思路:

这题和前面做过的 Regular Expression Matching 很像,思路也类似。用前面的思路去做,居然大数据的时候会超时。

public class Solution {
    public boolean isMatch(String s, String p) {
        return isMatchHelper(s, p, 0, 0);
    }
    
    public boolean isMatchHelper(String s, String p, int i, int j) {
        if(j >= p.length()) {
            return i >= s.length();
        }
        if(i >= s.length()) {
            return j >= p.length();
        }
        if(j == p.length() - 1) {
            return p.charAt(j) == ‘*‘ || p.charAt(j) == ‘?‘ || (i == s.length() - 1 && s.charAt(i) == p.charAt(j));
        }
        if(s.charAt(i) == p.charAt(j) || p.charAt(j) == ‘?‘) {
            return isMatchHelper(s, p, i + 1, j + 1);
        }
        if(p.charAt(j) == ‘*‘) {
            while(j < p.length()) {
                if(p.charAt(j) != ‘*‘) {
                    break;
                }
                j++;
            }
            if(j == p.length()) {
                return true;
            }
            while(i < s.length()) {
                if(isMatchHelper(s, p, i, j)) {
                    return true;
                }
                i++;
            }
        }
        return false;
    }
}

上面的超时,大数据的时候,估计是因为递归。下面用迭代做。

思路是一样的,遇到*的时候,就跳过下面连续的*,然后把i和j的下标保存,下面继续匹配。如果不匹配,i和j就退回保存的值,然后继续匹配。

public class Solution {
    public boolean isMatch(String s, String p) {
        int i = 0, j = 0, lastI = -1, lastJ = -1;
        while(i < s.length()) {
            if(j >= p.length()) {
                // 不能直接返回false,也要考虑退回的情况,比如"hi", "*?"
                if(lastI == -1) {
                    return false;
                }
                lastI++;
                i = lastI;
                j = lastJ;
                continue;
            }
            if(s.charAt(i) == p.charAt(j) || p.charAt(j) == ‘?‘) {
                i++;
                j++;
                continue;
            }
            if(p.charAt(j) == ‘*‘) {
                // p一次性略过下面连续的*
                while(j < p.length() && p.charAt(j) == ‘*‘) {
                    j++;
                }
                if(j == p.length()) {
                    return true;
                }
                // 保存已用来在s中做*匹配的尝试
                lastI = i;
                lastJ = j;
                // i++;
                continue;
            }
            if(s.charAt(i) != p.charAt(j)) {
                if(lastI == -1) {
                    return false;
                }
                // 不匹配就退回,i取下一个值继续尝试
                lastI++;
                i = lastI;
                j = lastJ;
            }
        }
        // s已经结束,除非j后面全是*,或者已经结束,不然不匹配
        while(j < p.length()) {
            if(p.charAt(j) != ‘*‘) {
                return false;
            }
            j++;
        }
        return true;
    }
}

 

Wildcard Matching

原文:http://www.cnblogs.com/NickyYe/p/4490990.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!