LeetCode No.10 Regular Expression Matching

没有思路,直接看的Solution。


思想:


一、 迭代法


假设s="ABCDE......",p="abcde......"

从s、p两字符串首字符进行比对,根据p第二个字符b是否等于‘*’分别进行处理。


(1)若b=‘*’,p="a*cde......",则a的出现次数为0~n

        (1.1)若s与p首字符不同(A!=a),a的出现次数必为0,此时忽略“a*”直接对后面字符进行匹配就可以了,即调用isMatch(s,p.substring(2))

        (1.2)若s与p首字符相同(A=a),则a的出现次数可能为0也可能大于0

                (1.2.1)若a的出现次数为0,同(1.1)

                (1.2.2)若a的出现次数大于0,此时应逐一判断s之后几个字符BCDE......是否等于a,即调用

                                isMatch(s.substring(1),p)


(2)若b!=‘*’,则判断s和p首字符A、a是否相同,若不相同则返回false,若相同则进一步判断之后的字符串

s.substring(1)和p.substring(1)



二、 动态规划

1. 与迭代法总体思路一致,增加布尔型数组 memo[i][j] 记录s,p字符串中下标ij对应的字符是否曾经比较过、是否匹配成功。

若之前已比较过,则根据memo直接返回是否匹配成功的结果即可,避免再次进行重复比较。


2. 在 1. 的基础上从字符串最后一个字符开始记录memo[i][j],这样可以保证计算memo[i][j]时,memo[i+...][j+...]都已经被赋值过了,省去了迭代调用函数的过程。



常用方法总结:

        String.substring(begin)表示截取范围从begin下标到字符串最后的子字符串。

        若String.length()=1,String.substring(1)="",String.substring(2)会抛出异常。


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值