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

正则表达式匹配

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);
}
全部评论

相关推荐

努力的小明a:项目看着很眼熟,施磊老师吧,我也学的这个😋我当时是把rpc框架做成了一个分布式网盘,这是一个项目,然后muduo库做成集群即时通讯,又用QT做了个交互的客户端,这样又一个项目,然后一个轻量redis,一个CAD,总共四个项目,投了三个月就今天2月份一个小厂Qt offer,然后后面想开了,Qt啥的都能干,这个月get了个北京大厂的offer,做java后端,人生就是这么魔幻,现在就在去北京入职的路上
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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