LeetCode 10 正则表达式匹配

100道题里的中等和简单级别的题基本都做完了,现在困难级别的来了。看完题目尝试暴力解来着,但是却觉得代码越写越复杂,越来越麻烦。果然困难题目难就难在这个分情况分类讨论了,真是分类分类,越分越“累”。那就来想各种可能的结果吧。

解法一:回溯

1、当s为空且p为空 —> 返回 true,否则返回 false

2、当p[1]!='*',且s[0]==p[0] || p[0]=='.' —> 对p[1:]和s[1:]进行匹配,否则返回 false

3、当p[1]==‘*’ —> 循环,每一次循环都对s[0:]和p[2:]或者在满足s[0]==p[0] || p[0]=='.'条件的情况下,令s[1:]和p进行匹配,二者有任一匹配,返回true,否则返回 false.

各种情况要进行分类,还要考虑各种细节的可能,感受到难度了,要学会顺着机器的思路,思考各种可能的情况,并将这些情况归类,分开依次解决。

func isMatch(s string, p string) bool {
    return SubMatch([]rune(s), []rune(p))
}

func SubMatch(s, p []rune) bool {
    if len(p)==0 { return len(s)==0 }
    if len(p)>1 && p[1]=='*'{
        return SubMatch(s, p[2:]) || (len(s)!=0 && (s[0]==p[0]||p[0]=='.') && SubMatch(s[1:], p))
    }else{
        return len(s)!=0 && (s[0]==p[0]||p[0]=='.') && SubMatch(s[1:], p[1:])
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值