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

【问题描述】[困难]

在这里插入图片描述

【解答思路】

在这里插入图片描述

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/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/425358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

annotation

Annotations提供一些本来不属于程序的数据。 注解(Annotation)相当于一种标记&#xff0c;在程序中加入注解就等于为程序打上某种标记&#xff0c;没有加&#xff0c;则等于没有任何标记&#xff0c;以后&#xff0c;javac编译器、开发工具和其他程序可以通过反射来了解你的类及…

43request对象 续

建立一个test.jsp <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"ISO-8859-1"> <title>Insert title here…

wannafly挑战赛4 C-割草机 思维

时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K 64bit IO Format: %lld 题目描述 有一块n*m的地&#xff0c;每块地要么长满杂草(用’W’表示)&#xff0c;要么是空地(用’G’表示)&#xff0c;现在有一个…

[剑指offer]面试题第[57]题[Leetcode][第167题][JAVA][和为s的两个数字][两数之和][HashSet][二分][双指针]

[剑指offer]面试题第[57]题[Leetcode][第167题][第1题] 有序无序之分 题目输出不同之分 以下解法按照[剑指offer]面试题第[57]题进行题解 【问题描述】[简单] 输入一个递增排序的数组和一个数字s&#xff0c;在数组中查找两个数&#xff0c;使得它们的和正好是s。如果有多对数…

44response对象

<% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8" import"java.util.*,java.io.*"%> <%out.println("<h1>response内置对象</h1>");out.println("<hr>&qu…

POJ 1703 Find them, Catch them 种类并查集

题意 给出一堆点和关系 D为两点不同集合 A为查询两点是否不同集合 n<1e5 code #include<cstdio> #include<iostream> #include<algorithm>using namespace std; const int maxn 1e57; int f[maxn],rel[maxn];//rel为0表示与父节点不同类 1为同类 …

2018java最新面试题

java面试题连接地址 https://blog.csdn.net/qq_41701956/article/details/80250226 https://juejin.im/post/5aacad4551882555642bd1b0 https://juejin.im/post/5ab1a338518825558a067c1f https://juejin.im/entry/5c6aba00e51d45719047035e转载于:https://www.cnblogs.com/liu…

45请求转发和请求重定向区别

请求转发 定义一个response的jsp文件 <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8" import"java.util.*,java.io.*"%> <%out.println("<h1>response内置对象</h1>&qu…

[签名算法]DSA 算法

DSA&#xff08;Digital Signature Algorithm&#xff09;是Schnorr和ElGamal签名算法的变种&#xff0c;被美国NIST作为DSS(DigitalSignature Standard)。 DSA是基于整数有限域离散对数难题的。 DSA是一种更高级的验证方式。一般用于数字签名和认证。DSA 不单单只有公钥、私钥…

Mahmoud and a Dictionary CodeForces - 766D 种类并查集

题意 给出多个字符串 然后再输入多个字符串之间的关系 让我们判断这其中是否存在矛盾的关系 有矛盾输出NO 没矛盾输出 YES 然后再输入多个询问 每个询问 两个字符串 让我们判断其中的关系 同义词输出1 反义词输出2 不确定输出3 分析 种类并查集 如果两个字符串的关系 是1 …

几位大佬启蒙老师和女神启蒙老师的博客,大家可以多关注下

Eva_J女神&#xff1a;https://www.cnblogs.com/Eva-J/ 太白金星&#xff1a;http://www.cnblogs.com/jin-xin/articles/7562422.html 金角大王等待唐僧的日子&#xff1a;https://www.cnblogs.com/alex3714/articles/5465198.html Mr.Seven 大佬&#xff1a;http://www.cnblog…

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

【问题描述】[中等] 【解答思路】 1. 动态规划流程 第 1 步&#xff1a;设计状态 第 2 步&#xff1a;状态转移方程 第 3 步&#xff1a;考虑初始化 第一行第一列 没有遇到“障碍” 就为1 如果u&#xff08;i&#xff0c;j&#xff09;0 直接返回 0 第 4 步&#xff1a;考虑…

47session 方法

定义一个page1 <% page language"java" import"java.util.*,java.text.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"utf-8"&…

Wincc V7.3SE安装截图

打开某个工程出错,能力所限,找不到问题,没能解决 转载于:https://www.cnblogs.com/guyk/p/10555965.html

[剑指offer]面试题第[57-2]题[JAVA][和为s的连续正数序列][数学法][滑动窗口]

【问题描述】[简单] 【解答思路】 1. 滑动窗口 时间复杂度&#xff1a;O(N) 空间复杂度&#xff1a;O(1) public int[][] findContinuousSequence(int target) {int i 1; // 滑动窗口的左边界int j 1; // 滑动窗口的右边界int sum 0; // 滑动窗口中数字的和List<int[]&…

[Leetcode][第112题][JAVA][路径总和][递归][队列]

【问题描述】[中等] 【解答思路】 1. 递归 时间复杂度&#xff1a;O(N) 空间复杂度&#xff1a;O(H) 从根节点开始&#xff0c;每当遇到一个节点的时候&#xff0c;从目标值里扣除节点值&#xff0c;一直到叶子节点判断目标值是不是被扣完。 class Solution {public boolean…

波动基因

突发奇想&#xff0c;会不会在癌症不同阶段中&#xff0c;同一个基因呈现出多峰的waving状态&#xff0c;这样的基因会不会在癌症阶段的转变中起着作用。 一个小想法&#xff0c;有空了做一下试试&#xff0c;现在暂时确定一下用信息熵来度量waving状态的程度。 坑越挖越多&…

[项目经验]玩转开源项目

搞懂一个开源项目的几大步骤 细看四大模块 1.首先正式开始啃开源项目之前&#xff0c;基础不可少&#xff0c;比如语言底子、网络协议、基本工具、基本应用框架、甚至包括一些设计模式等等&#xff0c;否则人家开源项目很难下牙。 2.正式看一个开源项目时&#xff0c;首先可以全…