Golang | Leetcode Golang题解之第10题正则表达式匹配

题目:

题解:

Go 复制代码
func isMatch(s string, p string) bool {
    m, n := len(s), len(p)
    matches := func(i, j int) bool {
        if i == 0 {
            return false
        }
        if p[j-1] == '.' {
            return true
        }
        return s[i-1] == p[j-1]
    }

    f := make([][]bool, m + 1)
    for i := 0; i < len(f); i++ {
        f[i] = make([]bool, n + 1)
    }
    f[0][0] = true
    for i := 0; i <= m; i++ {
        for j := 1; j <= n; j++ {
            if p[j-1] == '*' {
                f[i][j] = f[i][j] || f[i][j-2]
                if matches(i, j - 1) {
                    f[i][j] = f[i][j] || f[i-1][j]
                }
            } else if matches(i, j) {
                f[i][j] = f[i][j] || f[i-1][j-1]
            }
        }
    }
    return f[m][n]
}
相关推荐
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Morwit11 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣11 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
qinian_ztc12 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
Wenweno0o13 小时前
Eino - 错误处理与稳定性
golang·智能体·eino
田梓燊14 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
王码码203514 小时前
Go语言中的Elasticsearch操作:olivere实战
后端·golang·go·接口
Tomhex14 小时前
Go语言import用法详解
golang·go
小肝一下16 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
Tomhex16 小时前
Golang空白导入的真正用途
golang·go