力扣第十题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];
}
相关推荐
Qt程序员2 小时前
Linux .so 动态库:底层原理
linux·c++·内核·动态库
乌萨奇也要立志学C++2 小时前
【Linux】线程池(一)C++ 手写线程池:基于策略模式实现高性能日志模块
linux·c++·策略模式
Flying pigs~~2 小时前
我的leetcode hot100之行(持续更新)
数据结构·算法·leetcode
滴滴答滴答答2 小时前
机考刷题之 7 LeetCode 240 搜索二位矩阵Ⅱ
java·算法·leetcode
lihaihui19912 小时前
Linux C++知识梳理
linux·c++
仰泳的熊猫2 小时前
题目2086:蓝桥杯算法提高VIP-最长公共子序列
数据结构·c++·算法·蓝桥杯·动态规划
0 0 02 小时前
CCF-CSP 36-2 梦境巡查(dream)【C++】考点:前缀和
开发语言·c++·算法
luckycoding2 小时前
42. 接雨水
leetcode
天赐学c语言2 小时前
Linux - windows作为client访问linux服务端
linux·网络·c++