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

LeetCode 刷题【10. 正则表达式匹配】

10. 正则表达式匹配

自己做

思考

class Solution {
public:bool isMatch(string s, string p) {int i = 0, j = 0;int s_len = s.size();int p_len = p.size();while(i < s_len && j < p_len){if(s[i] != p[j]){if(p[j] == '.'){        //单字符省略i++;j++;}else if(p[j] == '*'){if(j > 0)                                       //如果第一个字符是*,直接忽略if(s[i] == p[j-1] || p[j-1] == '.'){                          //匹配成功i++;if(j < p_len - 1 && s[i] == p[j+1])                 //符号*结束使命【下一个字符成功匹配】j++;if(j == p_len - 1 && p[j] == '*')                                  //符号*结束使命【匹配串末尾】j++;}else                                                    //符号*结束使命【代表前面只有一个元素】j++;}else{                            //s[i] != p[j]并不会马上匹配失败,如果后面是*,则会忽略这个不一致【代表0个前面元素】if(j < p_len - 1 && p[j+1] == '*'){j += 2;}else                                    //真不匹配return false;}   }else{                                                   //s[i] == p[j]i++;j++;}}if(i == s_len && j == p_len)                //完全正确匹配return true;return false;}
};

看题解 【完全做不出】

class Solution {
public:bool isMatch(string s, string p) {int s_len = s.size(), p_len = p.size();vector<vector<bool>> dp(s_len + 1,vector<bool>(p_len + 1,false));       //初始化dp,默认都为false,即不匹配dp[0][0] = true;    //p前0位与s前0位(空字符串"")必匹配//针对s前面的空串""特别设置,如果能匹配上,则要求p的元素都能消除for (int i = 2; i < p_len + 1; i++) {       //当i = 1时,即p[0]如果为'*',直接忽略【*表示n个空字符串""】if (p[i - 1] == '*')            //如果能一直出现c*这样的成对子串,可以直接看作空串""【c*可以表示为0个c,即消除前面的任意字符,为空串""】dp[0][i] = dp[0][i - 2];    }for (int i = 1; i < s_len + 1; i++) {for (int j = 1; j < p_len + 1; j++) {if (s[i - 1] == p[j - 1] || p[j - 1] == '.') {      //该字符匹配dp[i][j] = dp[i - 1][j - 1];        //如果前面都匹配,那么加上该匹配的字符也匹配,否则不匹配}else if(p[j - 1] ==  '*'){          //不匹配,但是有*可以救一下if (s[i - 1] == p[j - 2] || p[j - 2] == '.') {      //匹配上了//dp[i][j - 2]表示*的作用是消除前面一个元素,即忽略dp[i][j - 1]的结果,匹配结果和dp[i][j - 2]保持一致【重复0次】//dp[i - 1][j - 2]表示将匹配的字符加上前面的匹配部分,如果前面匹配,那么加上后依然匹配,否则不匹配【重复1次】//dp[i - 1][j]表示s的当前字符与p的后一位字符匹配,结束*【重复多次结束】dp[i][j] = dp[i][j - 2] || dp[i - 1][j - 2] || dp[i - 1][j];    }else {                      //p对应*不能匹配上s的字符,则默认为消除前一个字符【重复0次】dp[i][j] = dp[i][j - 2];}}//都不匹配的情况下,默认为false}}return dp[s_len][p_len];}
};

今日总结

额是fw

http://www.dtcms.com/a/291357.html

相关文章:

  • CCF-GESP 等级考试 2025年6月认证C++六级真题解析
  • OTA升级失败,端口占用bind: Address already in use
  • 酵母杂交技术解析
  • 微服务项目文档
  • ABeam News | 中野洋辅董事长专访:扎根上海二十载,做中日企业的卓越桥梁
  • 【人工智能99问】什么是教师强制?(16/99)
  • Spring Cache 扩展:Redis 批量操作优化方案与 BatchCache 自定义实现
  • 2130、链表最大孪生和
  • rsync报错解决
  • Shopify 知识点
  • 草木知音的认知进化:Deepoc具身智能如何让除草机读懂花园的呼吸
  • 设备监控之数据处理(1)-概述
  • MQ 核心知识点笔记
  • Android开发中卡顿治理方案
  • 用基础模型构建应用(第十章)AI Engineering: Building Applications with Foundation Models学习笔记
  • 如何用纯 HTML 文件实现 Vue.js 应用,并通过 CDN 引入 Element UI
  • 【PHP 流程控制完全指南】
  • 多端适配灾难现场:可视化界面在PC/平板/大屏端的响应式布局实战
  • .NET依赖注入IOC你了解吗?
  • 开发避坑短篇(3):解决@vitejs plugin-vue@5.0.5对Vite^5.0.0的依赖冲突
  • 万界星空科技锂电池MES解决方案
  • Shell判断结构
  • voice模块
  • 【图论】CF——B. Chamber of Secrets (0-1BFS)
  • 标准文件I/O补充知识
  • paddleocr安装,数据集制作,训练自己的模型,调用训练好的模型
  • 20250721-day19
  • 【PTA数据结构 | C语言版】双连通分量
  • C# 实现:动态规划解决 0/1 背包问题
  • nextjs编程式跳转