题解 | #正则表达式匹配#

正则表达式匹配

http://www.nowcoder.com/practice/28970c15befb4ff3a264189087b99ad4

C++递归

bool match(string str, string pattern) {
    int str_length = str.size();
    int p_len = pattern.size();
    // base case
    if(str.empty()){
        if(p_len%2 != 0 )
            return false;
        else{
            if(p_len == 0)
                return true;
            int i = 1;
            while(i< p_len){
                if(pattern[i] != '*')
                    return false;
                i=i+2;
            }
            return true;
        }
    }
    if (pattern.empty())
        return false;
    char c_s = str[0];
    char c_pat = pattern[0];
    char c_star = 's';

    if (p_len>=2)
        c_star = pattern[1];
    //normal case
    if( c_star != '*' )
    {
        if(c_s == c_pat|| c_pat == '.')
            return match(str.substr(1, str_length-1), pattern.substr(1, p_len-1));
    }
    else
    {
        // ignore '*'
        if(c_s == c_pat|| c_pat == '.'){
        return match(str, pattern.substr(2, p_len-2))
            ||match(str.substr(1,str_length-1), pattern);

        }

        //else
        else{
            return match(str, pattern.substr(2, p_len-2));
        }

    }
    return false;
}
全部评论

相关推荐

Aurora23:属于挂一半,暂时进池子了,隔一段时间没有其他组捞的话就彻底结束了
点赞 评论 收藏
分享
10-28 17:30
已编辑
华东交通大学 Java
iori2333:这太正常了 我字节面了四五轮 没有一次是在官网投递 都是hr主动捞
秋招笔试记录
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务