对于该题,最简单的解法应该是动态规划。对于具体思路网上的解答很多。答题思路就是设置一个二维数组,第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为.*的情况。
之前一直觉得动态规划初始条件很好写,经过这道题发现,原来有些题的初始条件并不好写。。