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

正则表达式匹配

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


int match_core(char* str,char* pattern)
{
    if (*str == '\0' && *pattern == '\0')
        return 1;
    if (*str != '\0' && *pattern == '\0')
        return 0;
    if(*str == '\0' && *pattern != '\0')
    {
        if(pattern[1]=='*')
            return match_core(str, pattern+2);
        else
            return 0;
    }
    if (pattern[1] == '*')
    {
        if(pattern[0]==str[0]||pattern[0]=='.')
            return (match_core(str + 1, pattern)||match_core(str, pattern + 2));
        else
            return match_core(str, pattern+2);

    }
    else
    {
        if ((pattern[0] == '.') || pattern[0] == str[0])
            return match_core(str + 1, pattern + 1);
        else
            return 0;
    }

}



bool match(char* str, char* pattern ) {
    if (str == NULL || pattern == NULL)
        return 0;
    return match_core(str, pattern);
}
全部评论

相关推荐

点赞 评论 收藏
分享
01-26 22:20
已编辑
门头沟学院 Java
Java抽象带篮子:项目很nb了,现在好好准备八股和算法吧,早点找实习,可以看看我的置顶帖子。帖子里写了怎么改简历,怎么包装实习经历,还有2个高质量可速成的项目话术,和我的牛客八股笔记专栏
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务