No.010 Regular Expression Matching
10. Regular Expression Matching
- Total Accepted: 89193
- Total Submissions: 395441
- Difficulty: Hard
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 思路:
参考自:http://www.tuicool.com/articles/Ebiymu
- 首先要理解题意:
- "a"对应"a", 这种匹配不解释了
- 任意字母对应".", 这也是正则常见
- 0到多个相同字符x,对应"x*", 比起普通正则,这个地方多出来一个前缀x. x代表的是 相同的字符中取一个,比如"aaaab"对应是"a*b"
- "*"还有一个易于疏忽的地方就是它的"贪婪性"要有一个限度.比如"aaa"对应"a*a", 代码逻辑不能一路贪婪到底
 
- 正则表达式如果期望着一个字符一个字符的匹配,是非常不现实的.而"匹配"这个问题,非 常容易转换成"匹配了一部分",整个匹配不匹配,要看"剩下的匹配"情况.这就很好的把 一个大的问题转换成了规模较小的问题:递归
- 确定了递归以后,使用java来实现这个问题,会遇到很多和c不一样的地方,因为java对字符 的控制不像c语言指针那么灵活charAt一定要确定某个位置存在才可以使用.
- 如果pattern是"x*"类型的话,那么pattern每次要两个两个的减少.否则,就是一个一个 的减少. 无论怎样减少,都要保证pattern有那么多个.比如s.substring(n), 其中n 最大也就是s.length()
 public boolean isMatch(String s, String p) {
     // base case
     if (p.length() == 0) {
         return s.length() == 0;
     }
     // special case
     if (p.length() == 1) {
         // if the length of s is 0, return false
         if (s.length() < 1) {
             return false;
         }
         //if the first does not match, return false
         else if ((p.charAt(0) != s.charAt(0)) && (p.charAt(0) != '.')) {
             return false;
         }
         // otherwise, compare the rest of the string of s and p.
         else {
             return isMatch(s.substring(1), p.substring(1));
         }
     }
     // case 1: when the second char of p is not '*'
     if (p.charAt(1) != '*') {
         if (s.length() < 1) {
             return false;
         }
         if ((p.charAt(0) != s.charAt(0)) && (p.charAt(0) != '.')) {
             return false;
         } else {
             return isMatch(s.substring(1), p.substring(1));
         }
     }
     // case 2: when the second char of p is '*', complex case.
     else {
         //case 2.1: a char & '*' can stand for 0 element
         if (isMatch(s, p.substring(2))) {
             return true;
         }
         //case 2.2: a char & '*' can stand for 1 or more preceding element,
         //so try every sub string
         int i = 0;
         while (i<s.length() && (s.charAt(i)==p.charAt(0) || p.charAt(0)=='.')){
             if (isMatch(s.substring(i + 1), p.substring(2))) {
                 return true;
             }
             i++;
         }
         return false;
     }
 }
No.010 Regular Expression Matching的更多相关文章
- 【JAVA、C++】LeetCode 010 Regular Expression Matching
		Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ... 
- LeetCode--No.010 Regular Expression Matching
		10. Regular Expression Matching Total Accepted: 89193 Total Submissions: 395441 Difficulty: Hard Imp ... 
- 【LeetCode】010. Regular Expression Matching
		Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ... 
- 010 Regular Expression Matching 正则表达式匹配
		Implement regular expression matching with support for '.' and '*'.'.' Matches any single character. ... 
- LeetCode 010 Regular Expression Matching
		题目描述:Regular Expression Matching Implement regular expression matching with support for '.' and '*' ... 
- 《LeetBook》leetcode题解(10): Regular Expression Matching——DP解决正则匹配
		我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ... 
- No.010:Regular Expression Matching
		问题: Implement regular expression matching with support for '.' and '*'.'.' Matches any single charac ... 
- [LeetCode] Regular Expression Matching 正则表达式匹配
		Implement regular expression matching with support for '.' and '*'. '.' Matches any single character ... 
- [LeetCode] 10. Regular Expression Matching
		Implement regular expression matching with support for '.' and '*'. DP: public class Solution { publ ... 
随机推荐
- [Offer收割]编程练习赛4 A 满减优惠
			满减优惠 描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的 ... 
- 从视频文件中读入数据-->将数据转换为灰度图-->对图像做canny边缘检测-->将这三个结构显示在一个图像中
			//从视频文件中读入数据-->将数据转换为灰度图-->对图像做canny边缘检测-->将这三个结构显示在一个图像中 //作者:sandy //时间:2015-10-10 #inclu ... 
- c++学习-虚函数
			#include <iostream> using namespace std; class common{ public: virtual void hello(){cout<&l ... 
- shell中实现自动登录(bash环境脚本中)
			自己的脚本: #!/bin/bash expect -c " set timeout 3600; spawn su -; expect *assword:*; ... 
- 树莓派,使用opencv调用自带的摄像头
			OpenCV&Pi Cam – Step 1 : Install It’s quite easy to install your new Pi Camera. Installation pro ... 
- div高度自适应
			第一种: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3 ... 
- android之蓝牙设备的使用01
			<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ... 
- Java实现单向链表的增删改查
			class List<T> { private class Node { private T data; private Node next; private Node(T data) { ... 
- shell export
			export命令将使系统在创建每一个新的shell时定义这个变量的一个拷贝.这个过程称之为变量输出. 在脚本中export,跟在终端export原理一样. 他们都是一个子shell. http://b ... 
- flask test_client设置cookies
			class TestCase(unittest.TestCase): session = None def setUp(self): self.app = create_app() self.app. ... 
