2021-07-02:正则表达式匹配。给定一个字符串s和一个匹配串p。“.“匹配单个字符。“*“匹配左边元素的多个字符。判断p是否匹配s。比如s=“ab“,p=“a.“,返回true。比如s=“ab“
2021-07-02:正则表达式匹配。给定一个字符串s和一个匹配串p。".“匹配单个字符。”"匹配左边元素的多个字符。判断p是否匹配s。比如s=“ab”,p=“a.”,返回true。比如s=“ab”,p="a",返回false。比如s=“aaa”,p=“a*”,返回true。比如s=“moonfdd”,p="kmoonfdd",返回true,因为""表示零个或者多个,这里’k’表示0个。
福大大 答案2021-07-02:
为了更好的处理边界问题。s和p都追加"1"。比如s="",p=“cc”,加1后s=“1”,p=“cc1”。方法1递归和方法2动态规划都会用到。
1.自然智慧,递归。会递归就行,思想很重要。会了递归,动态规划也就会了。
si指针指向s中某个位置,pi指针指向p中某个位置。
1.1.pi+1不带星。
si指针右移1位,pi指针右移1位。
1.2.pi+1带星。
si指针右移1位,pi指针右移2位。匹配的时候。
si指针右移1位,pi指针右移0位。匹配的时候。
si指针右移0位,pi指针右移2位。匹配的时候和不匹配的时候。
2.动态规划。时间复杂度是O(MN),空间复杂度是O(MN)。
代码用golang编写。代码如下:
package main
import "fmt"
func main() {
s := "moonfdd"
p := "c*c*moonfddc*c*"
ret := isMatch(s, p)
fmt.Println(ret)
}
//递归
func isMatch(s string, p string) bool {
s = s + "1"
p = p + "1"
return process(s, 0, p, 0)
}
func process(s string, si int, p string, pi int) bool {
if si == len(s) && pi == len(p) {
return true
}
if si == len(s) || pi == len(p) {
return false
}
//pi+1是否是*
if pi+1 < len(p) && p[pi+1] == '*' {
if p[pi] == '.' || p[pi] == s[si] {
if process(s, si+1, p, pi) {
return true
}
if process(s, si+1, p, pi+2) {
return true
}
}
if process(s, si, p, pi+2) {
return true
}
} else {
if p[pi] == '.' || p[pi] == s[si] {
if process(s, si+1, p, pi+1) {
return true
}
}
}
return false
}
// 动态规划版本 + 斜率优化
func isMatch3(str string, pattern string) bool {
s := str + "1"
p := pattern + "1"
N := len(s)
M := len(p)
dp := make([][]bool, N+1)
for i := 0; i < N+1; i++ {
dp[i] = make([]bool, M+1)
}
dp[N][M] = true
for j := M - 1; j >= 0; j-- {
dp[N][j] = (j+1 < M && p[j+1] == '*') && dp[N][j+2]
}
// dp[0..N-2][M-1]都等于false,只有dp[N-1][M-1]需要讨论
if N > 0 && M > 0 {
dp[N-1][M-1] = s[N-1] == p[M-1] || p[M-1] == '.'
}
for i := N - 1; i >= 0; i-- {
for j := M - 2; j >= 0; j-- {
if p[j+1] != '*' {
dp[i][j] = ((s[i] == p[j]) || (p[j] == '.')) && dp[i+1][j+1]
} else {
if (s[i] == p[j] || p[j] == '.') && dp[i+1][j] {
dp[i][j] = true
} else {
dp[i][j] = dp[i][j+2]
}
}
}
}
return dp[0][0]
}
执行结果如下:

2021-07-02:正则表达式匹配。给定一个字符串s和一个匹配串p。“.“匹配单个字符。“*“匹配左边元素的多个字符。判断p是否匹配s。比如s=“ab“,p=“a.“,返回true。比如s=“ab“的更多相关文章
- python练习:编写一个函数isIn,接受两个字符串作为参数,如果一个字符串是另一个字符串的一部分,返回True,否则返回False。
python练习:编写一个函数isIn,接受两个字符串作为参数,如果一个字符串是另一个字符串的一部分,返回True,否则返回False. 重难点:定义函数的方法.使用str类型的find()函数,可以 ...
- 2021.07.02 P1383 高级打字机题解(可持久化平衡树)
2021.07.02 P1383 高级打字机题解(可持久化平衡树) 分析: 从可以不断撤销并且查询不算撤销这一骚操作可以肯定这是要咱建一棵可持久化的树(我也只会建可持久化的树,当然,还有可持久化并查集 ...
- 2021.07.02 UVa1197 多路归并模板
2021.07.02 UVa1197 多路归并模板 UVA11997 K Smallest Sums - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 分析: 题解 UVA11997 ...
- Js判断一个字符串是否包含一个子串
Js中经常遇到判断一个字符串是否包含一个子串,java语言中有containes的方法,直接调用就可以了.除非引用第三方数据库,Js中没有contains方法. 为了实现更java语言中contain ...
- HashTable集合和练习题_计算一个字符串中每一个字符出现的次数
HashTable集合 /** * java.util.Hashtable<K,V>集合 implement Map<K,V>接口 * Hashtable:底层也是一个哈希表, ...
- Java-map-第一题 (Map)利用Map,完成下面的功能: 从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队。如果该 年没有举办世界杯,则输出:没有举办世界杯。 附:世界杯冠军以及对应的夺冠年份,请参考本章附录。 附录
第一题 (Map)利用Map,完成下面的功能: 从命令行读入一个字符串,表示一个年份,输出该年的世界杯冠军是哪支球队.如果该 年没有举办世界杯,则输出:没有举办世界杯. 附:世界杯冠军以及对应的夺冠年 ...
- 获取一个字符串中每一个字母出现的次数使用map集合
package 获取字符串中单字符出现次数; import java.util.Scanner; import java.util.TreeMap; /* * 需求:获取一个字符串中每一个字母出现的次 ...
- oracle中一个字符串包含另一个字符串中的所有字符
oracle中一个字符串包含另一个字符串中的所有字符 --解决监理报告中所勾选的标段信息,与该用户所管理的标段字符串不匹配的问题. select * from a where instr(a,b)&g ...
- Java 一个字符串在另外一个字符串出现次数
统计一个字符串在另外一个字符串出现次数 代码如下: package me.chunsheng.javatest; import java.util.regex.Matcher; import java ...
- String 类中的几个练习--获取指定字符串中,大写字母、小写字母、数字的个数||获取一个字符串中,另一个字符串出现的次数
package cn.homework.demo1; public class GetCount { /* * 获取一个字符串中,另一个字符串出现的次数 * 思想: * 1. indexOf到字符串中 ...
随机推荐
- 截取屏幕 转为GIF 图片
近期winform 做的一个截取屏幕的软件给大家!谁要留言给我哦! sss
- (转载)一篇文章详解python的字符编码问题
一篇文章详解python的字符编码问题 一:什么是编码 将明文转换为计算机可以识别的编码文本称为"编码".反之从计算机可识别的编码文本转回为明文为"解码". ...
- Hugging Face 每周速递: Chatbot Hackathon;FLAN-T5 XL 微调;构建更安全的 LLM
每一周,我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新,包括我们的产品和平台更新.社区活动.学习资源和内容更新.开源库和模型更新等,我们将其称之为「Hugging Ne ...
- Python学习之爬虫
又被老师要求去搞Python ,曰,,下午回顾了一下Python的基础知识,写了个爬取图片的程序,在此做个分享吧.不喜勿喷 import requests import time from bs4 i ...
- Flink 编程接口(Flink SQL Table API DataStream API 和 DataSet API Stateful Stream Process API)
Flink 根据数据集类型的不同将核心数据处理接口分为两大类,一类是支持批计算的接口DataSet API,另外一类是支持流计算的接口 DataStream API.同时 Flink将数据处理接口抽象 ...
- vue-router面试题
1.vue-router怎么重定向页面? 答:路由中配置redirect属性 2.vue-router怎么配置404页面? 答:path: '*' 是对的 但是应该放在最后一个 3.切换路由时,需要保 ...
- selenium中处理验证码问题1-获取验证码图片
selenium中处理验证码问题: 验证码: 基本作用:可以实现当前访问页面的数据安全性.还可以减少用户的并发数:实现大流量的分流 类型:1.纯数字.纯字母 2.汉字组合 3.数学运算题 4.滑动 5 ...
- NodeJS 实战系列:个人开发者应该如何选购云服务
这文章至少值一千元,因为这是我保守估计花出去的冤枉钱(请自行脑补一个苦笑的 emoji) 文章中会穿插选择云服务的一些建议,当然也会提供一些"薅羊毛"的技巧.不过在此之前我们要想清 ...
- Thread 线程中的 Synchronized block and lock
Thread Definition of Synchronized Synchronized block in java are marked with the synchronized keywor ...
- 在Centos8中默认使用DNF没有使用YUM
1. 检查DNF版本 检查您的系统上安装的DNF版本. # dnf --version 2. 列出启用的DNF仓库 dnf命令中的'repolist'选项将显示您系统中所有启用的仓库. # dnf r ...