当前位置: 首页 > news >正文

手机网站搭建网时代教育培训机构官网

手机网站搭建,网时代教育培训机构官网,北京欢迎你 网站建设,东莞网站建设销售公司10. 正则表达式匹配 - 力扣(LeetCode) 此题的要求一个字符串 s 和一个字符规律 p之间支持 . 和 * 的正则表达式匹配 . 匹配任意单个字符 * 匹配零个或多个前面的那一个元素 所谓匹配,是要涵盖 整个 字符串 s 的,而不是部分字符串…

10. 正则表达式匹配 - 力扣(LeetCode)

此题的要求一个字符串 s 和一个字符规律 p之间支持 '.' 和 '*' 的正则表达式匹配

'.' 匹配任意单个字符
'*' 匹配零个或多个前面的那一个元素
所谓匹配,是要涵盖 整个 字符串 s 的,而不是部分字符串。

保证每次出现字符 * 时,前面都匹配到有效的字符 也就是说p中所有的 * 字符前的那个字符只会是 . 或者字母
示例 1:       输入:s = "a", p = ".*"        输出:true
示例 2:       输入:s = "aab", p = "c*a*b"        输出:true
示例 3:       输入:s = "a", p = "a*"        输出:true
示例 4:       输入:s = "a", p = ".*a"        输出:true

根据经验和题目要求,两个字符串的关系可以考虑二维dp表,

能够解决的leetcode中的1143. 最长公共子序列、72. 编辑距离中dp的建立相似,

dp[i][j]表示p[0.j]区间内的子串是否能够匹配s[0,i]区间内的子串

状态转移方程:根据 p 切出来的子串中的最后一个字符来分情况讨论,这种按两个子串的最后一个字符的取值来分情况讨论的方式,也是推导状态转移方程的普遍步骤,

记记dp[i][j] = x; dp[i - 1][j] = y; dp[i][j - 2] = z dp[i - 1][j - 1] = w

则当p[j - 1] 为字母或者 点号时,

只用通过 w 和 (s[i - 1] == p[j - 1] || p[j - 1] == '.')这个表达式是否为真就能更新dp[i][j]

当p[j - 1] 为星号时,

只用通过y 和 z 和(s[i - 1] == p[j - 2] || p[j - 2] == '.') 这个表达式是否为真就能更新dp[i][j]

图一 

读者可能会问了,道理我都懂,为什么使用了dp[i][j - 2] 来更新dp[i][j],而dp[i][j - 1]却没有使用?

 让我们来看看图一中  出现p[j - 1] == '*' && p[j - 2] == '.' 的情况

此时可以选择产生空串,或者将产生一个点号、两个点号,等等

那么dp[i][j] = dp[i][j - 2] || dp[i - 1][j - 2] || ...  dp[i - m][j - 2] || ...                                          (1)

令i = u - 1

则有dp[u - 1][j] = dp[u - 1][j - 2] || dp[u - 2][j - 2] || ... dp[u - m - 1][j - 2] || ...                      (2)

观察可知,可将(2)代入(1)中得到

dp[i][j] = dp[i][j - 2] || dp[i - 1][j]

让我们再来看看图一中  出现p[j - 1] == '*' && p[j - 2] != '.' 的情况

此时可以选择产生空串,或者将产生一个p[j - 1]、两个p[j - 1],等等

那么

dp[i][j] = dp[i][j - 2] || ((s[i -1] == p[j - 2]) && (dp[i - 1][j - 2])) || ... ((s[i - m] == p[j - 2]) && dp[i - m][j - 2] ) || ...                                                                                                                     (3)

令i = v - 1

则有dp[v - 1][j] = dp[v - 1][j - 2] || ( (s[v - 2] == p[j - 2]) && (dp[v - 2][j - 2]) ) || ... ( (s[v - m - 1] == p[j - 2]) && (dp[v - m - 1][j - 2]) ) || ...                                                                            (4)

观察可知,可将(4)代入(3)中,然后经过一些列的推导(具体步骤略),可以得到

dp[i][j] = dp[i][j - 2] || ( (s[i -1] == p[j - 2]) && dp[i - 1][j])

知道这道题为什么用到了dp[i][j - 2]了吧,但是还有一个很重要的问题,就是在编写这道题的程序的时候,可以给这个dp表多加一行,多加一列,所以

上面在访问原数组是 s[i - 1] 代表的就是第 i 个元素

那么多加的这一行/列是否可以赋予这个题目场景下的具体意义呢?

多加的一行,可以赋予dp[0][j] 一个意义,其意义就是s作为一个空串,匹配p[0, j]

如果在这种定义下,dp[0][j]要想为true,j 和 p[j] 必须满足以下条件才能保证匹配

dp[0, j] 是形如 {{非星号}{星号} {非星号}{星号} {非星号}{星号} {非星号}{星号}}

而dp[i][0] 此时只有在dp[0][0]处会为true

class Solution {
public:bool isMatch(string s, string p) {int len1 = s.size();int len2 = p.size();vector<vector<bool>> dp(len1 + 1, vector<bool>(len2 + 1, false));dp[0][0] = true;for(int j = 2; j <= len2; j += 2){if(p[j - 1] == '*'){dp[0][j] = true;}else{break;}}for(int i = 1; i <= len1; ++i){for(int j = 1; j <= len2; ++j){if(p[j - 1] != '*'){dp[i][j] = ((p[j - 1] == s[i - 1] || p[j - 1] == '.') && dp[i - 1][j - 1] == true);}else{dp[i][j] = ((dp[i][j - 2] == true) || ((p[j - 2] == s[i - 1] || p[j - 2] == '.') && (dp[i - 1][j] == true)));}}}return dp[len1][len2];}
};

http://www.khdw.cn/news/16395.html

相关文章:

  • wordpress ie6主题搜索引擎优化方式
  • 政府网站集约化建设通知人力资源短期培训班
  • 个人怎么进行网站建设seo优化网站教程百度
  • 关于建设网站的报告书百度推广一天费用200
  • 中山模板建站代理企业员工培训课程
  • 南县做网站盘多多百度网盘搜索引擎
  • 个人性质网站名称网络推广的优势有哪些
  • 做任务赚q币网站免费的电脑优化软件
  • 泰安做网站公司seo推广软件费用
  • wordpress 大数据插件seo外包公司是啥
  • 做网站要用服务器维护2022最火营销方案
  • .com免费网站怎么做网络营销策划书的结构是什么
  • 国家开发投资集团百度seo公司哪家好一点
  • 大厂县建设局网站素材网
  • 网购哪个网站最好世界搜索引擎大全
  • 企业网站续费免费发链接的网站
  • 高端品质网站建设谷歌排名查询
  • wordpress主题中英文win7最好的优化软件
  • 做网站选什么主机指数函数
  • 织梦网站如何做关键词百度seo快速排名
  • 企业网站站内优化电子商务网页制作
  • 网页升级中每天自动更新什么意思武汉外包seo公司
  • 网页制作与网站建设江西网站托管维护
  • 中文网站建设广告大全
  • 新手做网站优化怎么做2022百度收录越来越难了
  • 凡科网站设计模板可以放友情链接的网站
  • 青岛网站seo诊断方象科技专注于什么领域
  • 国外 上海网站建设google竞价推广
  • 哪些人做数据监测网站在线建站模板
  • 网站2级目录怎么做的苏州首页关键词优化