力扣第十题C++正则表达式匹配

题目

知识点

正则表达式

字符匹配

regex

题解

动态规划

注意或等于|=

cpp 复制代码
auto singleMatch(char c_s, char c_p) {
    if (c_s == '1') return false;//1和字符都不匹配
    if (c_p == '.') return true;//.和任何字符都匹配
    return c_s == c_p;//既不是1也不是.,直接返回两者比较后的结果
}
bool isMatch(string s, string p) {
    s = '1' + s;//占位字符
    p = '1' + p;

    int m = s.size();
    int n = p.size();
    //创建二维数组f,初始化都为false,f有m列,每列n个元素
    vector<vector<int>> f(m, vector<int>(n, false));
    f[0][0] = true;

    //按列填
    for (int i = 0; i < m; i++) {
        for (int j = 0; j < n; j++) {
            if (p[j] == '*') {
                f[i][j] |= f[i][j - 2];//f[i][j] = f[i][j] || f[i][j - 2]
                if (singleMatch(s[i], p[j - 1])) {
                    f[i][j] |= f[i - 1][j];
                }
            }
            else {
                if ( singleMatch(s[i], p[j]) ) {
                    f[i][j] |= f[i - 1][j - 1];
                }
            }
        }//j
    }//i
    return f[m - 1][n - 1];
}
相关推荐
卷无止境6 小时前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境7 小时前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
To_OC19 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
To_OC1 天前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
郝学胜_神的一滴1 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
To_OC2 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
卷无止境3 天前
C++ 的Eigen 库全解析
c++
卷无止境3 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴3 天前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
To_OC4 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode