【问题描述】[困难]

【解答思路】

1. 动态规划

第 1 步:设计状态
dp[i][j]dp[i][j] 表示字符串 ss 的前 ii 个字符和模式 pp 的前 jj 个字符是否能匹配
第 2 步:状态转移方程

第 3 步:考虑初始化
boolean[][] dp = new boolean[m + 1][n + 1];

第 4 步:考虑输出
dp[m][n];

时间复杂度:O(MN) 空间复杂度:O(MN)

public boolean isMatch(String s, String p) {int m = s.length();int n = p.length();boolean[][] dp = new boolean[m + 1][n + 1];dp[0][0] = true;for(int i=1 ;i<=n;i++){if(p.charAt(i-1)== '*'){dp[0][i]=true;}else{break;}}for(int i=1;i<=m;i++){for(int j=1;j<=n;j++){if(p.charAt(j-1)=='*'){dp[i][j]= dp[i-1][j]|dp[i][j-1]; }else if((p.charAt(j-1) == s.charAt(i-1))||(p.charAt(j-1)=='?')){dp[i][j]= dp[i-1][j-1]; }}}return dp[m][n];}
2. 贪心

// 我们用 sIndex 和 pIndex 表示当前遍历到 s 和 p 的位置
// 此时我们正在 s 中寻找某个 u_i
// 其在 s 和 p 中的起始位置为 sRecord 和 pRecord// sIndex 和 sRecord 的初始值为 0
// 即我们从字符串 s 的首位开始匹配
sIndex = sRecord = 0// pIndex 和 pRecord 的初始值为 1
// 这是因为模式 p 的首位是星号,那么 u_1 的起始位置为 1
pIndex = pRecord = 1while sIndex < s.length and pIndex < p.length doif p[pIndex] == '*' then// 如果遇到星号,说明找到了 u_i,开始寻找 u_i+1pIndex += 1// 记录下起始位置sRecord = sIndexpRecord = pIndexelse if match(s[sIndex], p[pIndex]) then// 如果两个字符可以匹配,就继续寻找 u_i 的下一个字符sIndex += 1pIndex += 1else if sRecord + 1 < s.length then// 如果两个字符不匹配,那么需要重新寻找 u_i// 枚举下一个 s 中的起始位置sRecord += 1sIndex = sRecordpIndex = pRecordelse// 如果不匹配并且下一个起始位置不存在,那么匹配失败return Falseend if
end while// 由于 p 的最后一个字符是星号,那么 s 未匹配完,那么没有关系
// 但如果 p 没有匹配完,那么 p 剩余的字符必须都是星号
return all(p[pIndex] ~ p[p.length - 1] == '*')


时间复杂度:O(MN) 空间复杂度:O(MlogN)

class Solution {public boolean isMatch(String s, String p) {int sRight = s.length(), pRight = p.length();while (sRight > 0 && pRight > 0 && p.charAt(pRight - 1) != '*') {if (charMatch(s.charAt(sRight - 1), p.charAt(pRight - 1))) {--sRight;--pRight;} else {return false;}}if (pRight == 0) {return sRight == 0;}int sIndex = 0, pIndex = 0;int sRecord = -1, pRecord = -1;while (sIndex < sRight && pIndex < pRight) {if (p.charAt(pIndex) == '*') {++pIndex;sRecord = sIndex;pRecord = pIndex;} else if (charMatch(s.charAt(sIndex), p.charAt(pIndex))) {++sIndex;++pIndex;} else if (sRecord != -1 && sRecord + 1 < sRight) {++sRecord;sIndex = sRecord;pIndex = pRecord;} else {return false;}}return allStars(p, pIndex, pRight);}public boolean allStars(String str, int left, int right) {for (int i = left; i < right; ++i) {if (str.charAt(i) != '*') {return false;}}return true;}public boolean charMatch(char u, char v) {return u == v || v == '?';}
}

【总结】

1.动态规划流程

第 1 步:设计状态
第 2 步:状态转移方程
第 3 步:考虑初始化
第 4 步:考虑输出
第 5 步:考虑是否可以状态压缩

2.贪心 字符串匹配 细心分情况

转载链接:https://leetcode-cn.com/problems/wildcard-matching/solution/tong-pei-fu-pi-pei-by-leetcode-solution/

[Leetcode][第44题][JAVA][通配符匹配][贪心][动态规划]相关推荐

  1. [Leetcode][第337题][JAVA][打家劫舍3][递归][动态规划]

    [问题描述][中等] [解答思路] 1. 动态规划 第 1 步:状态定义 dp[node][j] :这里 node 表示一个结点,以 node 为根结点的树,并且规定了 node 是否偷取能够获得的最 ...

  2. [Leetcode][第647题][JAVA][回文子串][动态规划][中心扩展][Manacher 算法]

    [问题描述][中等] [解答思路] 1. 暴力 首先明确如何判断一个字符串是否为回文字符串.第一个字符与最后一个字符相同,第二个字符与倒数第二个字符相同-关于中心位置轴对称. 本题要求一共有多少个回文 ...

  3. [Leetcode][第174题][JAVA][地下城游戏][DFS][动态规划]

    [问题描述][中等] [解答思路] 1. 回溯(暴力)& 优化 超时,需要优化 public int calculateMinimumHP(int[][] dungeon) {if (dung ...

  4. [Leetcode][第97题][JAVA][交错字符串][BFS][动态规划]

    [问题描述][中等] [解答思路] 1. 动态规划 第 1 步:设计状态 f(i,j) 表示 s 1的前 i个元素和 s2 的前 j个元素是否能交错组成 s3的前 i + j 个元素 第 2 步:状态 ...

  5. [Leetcode][第63题][JAVA][不同路径2][动态规划][压缩路径]

    [问题描述][中等] [解答思路] 1. 动态规划流程 第 1 步:设计状态 第 2 步:状态转移方程 第 3 步:考虑初始化 第一行第一列 没有遇到"障碍" 就为1 如果u(i, ...

  6. [Leetcode][第889题][JAVA][根据前序和后序遍历构造二叉树][分治][递归]

    [问题描述][中等] [解答思路] copyOfRange class Solution {public TreeNode constructFromPrePost(int[] pre, int[] ...

  7. [Leetcode][第106题][JAVA][ 从中序与后序遍历序列构造二叉树][分治][递归]

    [问题描述][中等] [解答思路] public class Solution {public TreeNode buildTree(int[] inorder, int[] postorder) { ...

  8. [Leetcode][第78题][JAVA][子集][位运算][回溯]

    [问题描述][中等] [解答思路] 1. 位运算 复杂度 class Solution {List<Integer> t = new ArrayList<Integer>(); ...

  9. [Leetcode][第79题][JAVA][单词搜索][DFS][回溯]

    [问题描述][中等] [解答思路] 1. DFS繁琐版本 class Solution {public boolean exist(char[][] board, String word) {bool ...

最新文章

  1. android 控件id为0,Android Studio错误:(3,0)未找到ID为“com.android.application”的插件...
  2. 【ZooKeeper Notes 28】ZooKeeper典型应用场景一览
  3. 服务器定期巡检项目,服务器定期巡检制度..docx
  4. Windows下安装和配置tomca(免安装版本)
  5. mysql的传播特性_spring事务传播特性和mysql事务隔离级别
  6. idea 关联jdk源码_[项目源码]ERP进销存系统
  7. mysql转移数增删改查_MySql CURD操作(数据的增删改查)
  8. sklearn模型支持输入list吗?
  9. 基于 HTML5 WebGL 的 3D 工控裙房系统
  10. 极光开发者周刊【No.0827】
  11. DSP CCS12.00 芯片:TMS320F28335 外部中断 XINT1, 和映射区域的 k1 -- k4 按键的功能实现
  12. RTSP流媒体播放器实现
  13. 虚拟手游服务器,自己搭建手机游戏服务器
  14. c++ 向量化_一种新的FIR滤波器系数量化方法
  15. Oracle Database 12c新特性 In-Database Archiving数据库内归档
  16. 【AWS+Drupal应用案例】如何让一个千万级流量网站从一直挂机到起死回生?
  17. python中matplotlib绘图中文显示问题
  18. DOM windows对象 navigator对象 详细介绍
  19. 云开工第一天,视频会议哪家强?
  20. 云盘构建LVM linux 持续更新

热门文章

  1. linux6.4 安装oracle11g 出现错误ORA-01078和LRM-00109错误
  2. Qt+ArcGIS Engine 10.1 开发(一)
  3. 【eoe特刊】第二十七期 OpenGL ES学习及项目解析
  4. 只进ResultSet 不支持请求的操作
  5. C# 淘宝商品微信返利助手开发-(六)返利助手开发(4)如何通过淘口令解析的出来的地址获得返利信息
  6. 使用babel7 和 nodemon 进行node项目开发
  7. 鲲鹏920 centos7 postgresql12 postgis2.5.4编译
  8. centos7.1 postgresql10+postgis2.5离线安装
  9. jquery ajax json转换出错Invalid JSON
  10. 4线电子围栏安装示意图_电子围栏报警系统安装施工过程(图解)