10 正则表达式匹配

题目链接

对于该题,最简单的解法应该是动态规划。对于具体思路网上的解答很多。答题思路就是设置一个二维数组,第i,j位置代表p的前i个字符子串与s的前j个字符子串是否匹配。对于具体递推公式这儿不再赘述。

但是我们需要注意一点。对于一个m长的p和n长的q。我们需要设置的二维数组大小为m+1,n+1(二维数组行列可互换,即行代表p或s皆可)。为什么要加1,是因为对于m长的p,我们需要考虑p的空子串。即需要考虑s匹配空的情况。同理,我们需要考虑s为空,可以匹配p的情况。举个栗子,我们需要考虑s为空,可以匹配p为.*的情况。

之前一直觉得动态规划初始条件很好写,经过这道题发现,原来有些题的初始条件并不好写。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值