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

leetcode做题笔记44

给你一个输入字符串 (s) 和一个字符模式 (p) ,请你实现一个支持 '?' 和 '*' 匹配规则的通配符匹配:
'?' 可以匹配任何单个字符。
'*' 可以匹配任意字符序列(包括空字符序列)。
判定匹配成功的充要条件是:字符模式必须能够 完全匹配 输入字符串(而不是部分匹配)。

目录

思路一:动态规划

分析:

总结:


思路一:动态规划

bool isMatch(char * s, char * p){int lens = strlen(s),lenp = strlen(p);int**dp = (int**)malloc(sizeof(int*)*(lens+1));for (int i = 0; i <= lens; ++i){*(dp+i) = (int*)malloc(sizeof(int)*(lenp+1));memset(*(dp+i), 0, sizeof(int)*(lenp+1));}dp[0][0] = 1;for(int i = 1;i<=lenp;i++){if(p[i-1]=='*')dp[0][i] = 1;else break;}for (int i = 1; i <= lens; i++){for (int j = 1; j <= lenp; j++){if (s[i-1] == p[j-1])dp[i][j] = dp[i-1][j-1];else{if (p[j-1] == '?')dp[i][j] = dp[i-1][j-1];else if (p[j-1] == '*')dp[i][j] = dp[i-1][j-1] || dp[i][j-1] || dp[i-1][j];}}}return dp[lens][lenp];
}

时间复杂度O(n^3),空间复杂度O(n^2)

分析:

本题要实现*和?的匹配机制,可将每次匹配的字符放入一个二位数组判断是否用过,通过每列判断是否符合设置二维数组该位置的值。最后输出该位置的值

总结:

本题可使用动态规划和回溯解法进行解答,主要考察了对动态规划及回溯的应用,利用字符判断设置二维数组值后输出。

http://www.lryc.cn/news/96730.html

相关文章:

  • mac brew安装 node 踩坑日记- n切换node不生效
  • 数据预处理matlab
  • ubuntu18.04安装autoware1.15
  • 在CSDN学Golang云原生(Docker基础)
  • Zookeeper命令总结
  • C语言中的函数(超详细)
  • 华为H3C思科网络设备命令对照表
  • 产品需求、系统架构设计经验篇
  • 关于websocket的几点注意事项
  • go学习 4、复合数据类型
  • Rust: Vec类型的into_boxed_slice()方法
  • Python - Opencv + pyzbar实时摄像头识别二维码
  • 网络安全(黑客)就业分析指导
  • MySQL 主从复制的认识 2023.07.23
  • elasticsearch查询操作(API方式)
  • Java版企业工程项目管理系统源码+java版本+项目模块功能清单+spring cloud +spring boot
  • 理解Android中不同的Context
  • linux判断端口是否占用(好用)
  • springboot 自定义注解 ,实现接口限流(计数器限流)【强行喂饭版】
  • istio安装部署总结
  • Linux操作系统~必考面试题⑨
  • 国标GB28181协议视频平台EasyCVR修改录像计划等待时间较长的原因排查与解决
  • 线性代数(主题篇):第三章:向量组 、第四章:方程组
  • 大数据课程C4——ZooKeeper结构运行机制
  • 解决伪类元素‘after‘或者‘before‘遮挡父元素,导致鼠标移入或点击等事件不生效的问题
  • 电动汽车市场的减速,正在让小鹏汽车付出代价
  • Yarn上Streaming流自动调节资源设计
  • 微信小程序的个人博客--【小程序花园】
  • 智慧园区楼宇合集 | 图扑数字孪生管控系统
  • 【代码随想录day21】二叉搜索树中的众数