10. Regular Expression Matching
来源:互联网 发布:现在常用的数据库 编辑:程序博客网 时间:2024/06/03 16:41
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") → falseisMatch("aa","aa") → trueisMatch("aaa","aa") → falseisMatch("aa", "a*") → trueisMatch("aa", ".*") → trueisMatch("ab", ".*") → trueisMatch("aab", "c*a*b") → true
思路:
1、”a”对应”a”, 这种匹配不解释了
2、任意字母对应”.”, 这也是正则常见
3、0到多个相同字符x,对应”x*”, 比起普通正则,这个地方多出来一个前缀x. x代表的是 相同的字符中取一个,比如”aaaab”对应是”a*b”
4、”*”还有一个易于疏忽的地方就是它的”贪婪性”要有一个限度.比如”aaa”对应”a*a”, 代码逻辑不能一路贪婪到底
5、正则表达式如果期望着一个字符一个字符的匹配,是非常不现实的.而”匹配”这个问题,非 常容易转换成”匹配了一部分”,整个匹配不匹配,要看”剩下的匹配”情况.这就很好的把 一个大的问题转换成了规模较小的问题:递归
6、确定了递归以后,使用java来实现这个问题,会遇到很多和c不一样的地方,因为java对字符 的控制不像c语言指针那么灵活charAt一定要确定某个位置存在才可以使用.
7、如果pattern是”x*”类型的话,那么pattern每次要两个两个的减少.否则,就是一个一个 的减少. 无论怎样减少,都要保证pattern有那么多个.比如s.substring(n), 其中n 最大也就是s.length()
class Solution { public boolean isMatch(String s, String p) { if (p.length() == 0) return s.length() == 0; // length == 1 is the case that is easy to forget. // as p is subtracted 2 each time, so if original // p is odd, then finally it will face the length 1 if (p.length() == 1) return (s.length() == 1) && (p.charAt(0) == s.charAt(0) || p.charAt(0) == '.'); // next char is not '*': must match current character if (p.charAt(1) != '*') { if (s.length() == 0) return false; else return (s.charAt(0) == p.charAt(0) || p.charAt(0) == '.') && isMatch(s.substring(1), p.substring(1)); }else{ // next char is * while (s.length() > 0 && (p.charAt(0) == s.charAt(0) || p.charAt(0) == '.')) { if (isMatch(s, p.substring(2))) return true; s = s.substring(1); } return isMatch(s, p.substring(2)); } }}
阅读全文
0 0
- 10. Regular Expression Matching
- 10.Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- 10. Regular Expression Matching
- day06_debug+泛型+枚举+静态导入+自动装拆箱
- Mysql修改密码Warning: single quotes were not trimmed line client, as you might have expected.
- 使用Sublime Text 开发Python如何配置环境(windows 7)
- Tensorflow的GPU配置:ubuntu16.04+375.26驱动+cuda8.0+cudnn5
- Vijos P1688 病毒传递
- 10. Regular Expression Matching
- H5页面定时器
- LINUX 系统备份和恢复(通过虚拟机试验)
- Gradle学习(六)——多项目构建
- 【Linux】【Windows】32/64,文件系统,磁盘分区,X86/ARM
- 仿qq横向滑动删除的 SwipeMenuListView
- Python爬虫---scrapy框架
- 微信支付兴起,万亿级用户交易记录存储的挑战
- WebService的发布流程和配置