《剑指offer》正则表达式匹配
来源:互联网 发布:nginx 域名 映射 路径 编辑:程序博客网 时间:2024/05/01 14:46
【 声明:版权所有,转载请标明出处,请勿用于商业用途。 联系信箱:libin493073668@sina.com】
题目链接:http://www.nowcoder.com/practice/45327ae22b7b413ea21df13ee7d6429c?rp=3&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
题目描述
请实现一个函数用来匹配包括'.'和'*'的正则表达式。模式中的字符'.'表示任意一个字符,而'*'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"ab*ac*a"匹配,但是与"aa.a"和"ab*a"均不匹配
思路
如果模式串此时是'.',那么只需要模式串与匹配串都往后移动一个位置即可
如果现在这位的字符能匹配且且模式串的下一位是'*',我们则需要分情况讨论
1.匹配串往后移动1位,模式串跳过'*'
2.匹配串往后移动1位,模式串不动
3.匹配串不动,模式串跳过'*'
class Solution{public:bool match(char* str, char* pattern){if(str==nullptr || pattern==nullptr)return false;return matchCore(str,pattern);}bool matchCore(char *str,char *pattern){if(*str=='\0' && *pattern=='\0')return true;if(*str!='\0' && *pattern=='\0')return false;if(*(pattern+1)=='*'){if(*str==*pattern || (*pattern=='.' && *str!='\0'))return matchCore(str+1,pattern+2)||matchCore(str+1,pattern)||matchCore(str,pattern+2);elsereturn matchCore(str,pattern+2);}if(*str==*pattern || (*pattern=='.' && *str!='\0'))return matchCore(str+1,pattern+1);return false;}};
0 0
- 《剑指offer》正则表达式匹配
- 剑指offer--正则表达式匹配
- 剑指offer:正则表达式匹配
- [剑指offer]正则表达式匹配
- 剑指offer-正则表达式匹配
- 剑指offer|正则表达式匹配
- 《剑指offer》-正则表达式匹配
- 剑指offer-正则表达式匹配
- 【剑指offer】正则表达式匹配
- 【剑指offer】正则表达式匹配
- 剑指offer-正则表达式匹配
- 剑指offer:正则表达式匹配
- 剑指Offer---正则表达式匹配
- 剑指offer 53-正则表达式匹配
- 剑指offer—正则表达式匹配
- 正则表达式匹配(递归+剑指offer)
- 《剑指offer》——正则表达式匹配
- 正则表达式匹配-剑指offer(JAVA版)
- 【开源项目解析】QQ“一键下班”功能实现解析——学习Path及贝塞尔曲线的基本使用
- hdu 1131 Count the Trees 卡特兰数+java
- WM_NOTIFY Message
- 什么是关系型数据库
- LCA小结
- 《剑指offer》正则表达式匹配
- io流中的字节和字符
- Spring MVC XmlViewResolver example
- hibernate3(1)
- 重建二叉树
- 如何创建无名文件夹?
- 关于Ubuntu12.04下gedit不能使用中文输入法的问题
- Android开发实现按两次返回键退出的方法
- hibernate3(2)