LeetCode - 10. Regular Expression Matching

简介: 10. Regular Expression Matching Problem's Link  ---------------------------------------------------------------------------- Mean:  给定一个串s和一个自动机p(模糊字符只含有'.

 10. Regular Expression Matching

Problem's Link

 ----------------------------------------------------------------------------

Mean: 

给定一个串s和一个自动机p(模糊字符只含有'.'和'*'),问串s是否能够和自动机p匹配.

analyse:

由于模糊字符只含有'.'和'*',可不构造自动机.

直接用动态规划来做即可.

Time complexity: O(N)

 

view code

class Solution
{
public :
    bool isMatch( string s , string p)
    {
        if(p . empty())
            return s . empty();
       
        if(p [ 1 ] == '*')
            return isMatch(s ,p . substr( 2))
                   || ( !s . empty() && (s [ 0 ] ==p [ 0 ] || '.' ==p [ 0 ]) && isMatch(s . substr( 1 ),p));
        else
            return !s . empty() && (s [ 0 ] ==p [ 0 ] || '.' == p [ 0 ]) && isMatch(s . substr( 1 ),p . substr( 1));
    }
};
目录
相关文章
|
C++ Python 算法
leetcode 10 Regular Expression Matching(简单正则表达式匹配)
最近代码写的少了,而leetcode一直想做一个python,c/c++解题报告的专题,c/c++一直是我非常喜欢的,c语言编程练习的重要性体现在linux内核编程以及一些大公司算法上机的要求,python主要为了后序转型数据分析和机器学习,所以今天来做一个难度为hard 的简单正则表达式匹配。
1350 0
[LeetCode] Regular Expression Matching
This problem has a typical solution using Dynamic Programming. We define the state P[i][j] to be true if s[0.
849 0
|
3月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
4月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
121 2