[Leetcode]10. Regular Expression Matching @python
来源:互联网 发布:apache tomcat9.0安装 编辑:程序博客网 时间:2024/06/05 03:32
题目
Implement regular expression matching with support for ‘.’ and ‘*’.
‘.’ Matches any single character.
‘*’ Matches zero or more of the preceding element.
The matching should cover the entire input string (not partial).
The function prototype should be:
bool isMatch(const char *s, const char *p)
Some examples:
isMatch(“aa”,”a”) → false
isMatch(“aa”,”aa”) → true
isMatch(“aaa”,”aa”) → false
isMatch(“aa”, “a*”) → true
isMatch(“aa”, “.*”) → true
isMatch(“ab”, “.*”) → true
isMatch(“aab”, “c*a*b”) → true
题目要求
实现正则表达式的匹配。函数isMatch接收字符串s和正则表达式p,正则表达式要支持’.’和’*’操作,其中’.’可以表示任意一个字符,’*’表示0个或多个前面的字符。可以通过例子理解正则表达式。
解题思路
本题参考了南郭子綦的代码。使用动态规划进行求解。dp[i][j] 表示s中前i个字符与p的前j个字符组成的表示式是否匹配。dp[0][0]恒为True,对于i为0的情况,空串可以匹配到p前面的表达式为.* 或c*这种情况(c为任意字符).
代码
class Solution(object): def isMatch(self, s, p): """ :type s: str :type p: str :rtype: bool """ dp = [[False for _ in range(len(p) + 1)] for _ in range(len(s) + 1)] dp[0][0] = True for j in range(2,len(p) + 1): if p[j - 1] == '*': dp[0][j] = dp[0][j - 2] for i in range(1,len(s) + 1): for j in range(1,len(p) + 1): if p[j - 1] == '*': dp[i][j] = dp[i][j-1] or dp[i][j-2] or (dp[i-1][j] and (s[i-1] == p[j-2] or p[j-2] == '.')) elif p[j-1] == '.' or s[i-1] == p[j - 1]: dp[i][j] = dp[i-1][j-1] return dp[len(s)][len(p)]
- 10. Regular Expression Matching Leetcode Python
- [Leetcode]10. Regular Expression Matching @python
- Leetcode(python)--10.Regular Expression Matching
- [LeetCode]10.Regular Expression Matching
- LeetCode --- 10. Regular Expression Matching
- [Leetcode] 10. Regular Expression Matching
- [LeetCode]10.Regular Expression Matching
- [leetcode] 10.Regular Expression Matching
- Leetcode-10.Regular Expression Matching
- leetcode 10. Regular Expression Matching
- leetcode 10. Regular Expression Matching
- Leetcode 10. Regular Expression Matching
- leetcode 10. Regular Expression Matching
- Leetcode 10. Regular Expression Matching
- leetcode 10. Regular Expression Matching
- LeetCode-10. Regular Expression Matching
- leetcode.10. Regular Expression Matching
- LeetCode 10. Regular Expression Matching
- bash array length
- JSTL---Servlet.service() for servlet action threw exceptionjavax.el.MethodNotFoundException Method s
- error C4013: 'RtlStringCbPrintf' undefined; assuming extern returning int
- Uva1629:Cake slicing
- jenkins+maven+svn构建项目,及远程部署war包到tomcat上
- [Leetcode]10. Regular Expression Matching @python
- Codeforces Round #339 (Div. 2)D. Skills
- 【转】图解HTTPS
- JVM学习笔记(六)--- 垃圾回收面临的问题
- http-关于content-type等字符编码的解释说明
- poj DNA Sorting
- 214,使用storyboard实现页面跳转
- 菜单展开缩放联动
- error LNK2019: unresolved externalsymbol _RtlStringVPrintfWorkerA@20 referenced in function _RtlStri