内容简介:给定一个字符串
给定一个字符串 (s) 和一个字符模式 (p) ,实现一个支持 '?' 和 '*' 的通配符匹配。
'?' 可以匹配任何单个字符。
'*' 可以匹配任意字符串(包括空字符串)。
两个字符串完全匹配才算匹配成功。
说明:
s 可能为空,且只包含从 a-z 的小写字母。
p 可能为空,且只包含从 a-z 的小写字母,以及字符 ? 和 * 。
示例 1:
输入:
s = "aa"
p = "a"
输出: false
解释: "a" 无法匹配 "aa" 整个字符串。
示例 2:
输入:
s = "aa"
p = "*"
输出: true
解释: '*' 可以匹配任意字符串。
示例 3:
输入:
s = "cb"
p = "?a"
输出: false
解释: '?' 可以匹配 'c' , 但第二个 'a' 无法匹配 'b' 。
示例 4:
输入:
s = "adceb"
p = "*a*b"
输出: true
解释: 第一个 '*' 可以匹配空字符串, 第二个 '*' 可以匹配字符串 "dce" .
示例 5:
输入:
s = "acdcb" p = "a*c?b" 输入: false
参考
/**
* @param {string} s
* @param {string} p
* @return {boolean}
*/
var isMatch = function (s, p) {
// 构造 dp 函数
let dp = []
for (let i = 0; i <= s.length; i++) {
let child = []
for (let j = 0; j <= p.length; j++) {
child.push(false)
}
dp.push(child)
}
dp[s.length][p.length] = true
// 执行
for (let i = p.length - 1; i >= 0; i--) {
if (p[i] != "*") break
else dp[s.length][i] = true
}
for (let i = s.length - 1; i >= 0; i--) {
for (let j = p.length - 1; j >= 0; j--) {
if (s[i] == p[j] || p[j] == "?") {
dp[i][j] = dp[i + 1][j + 1]
} else if (p[j] == "*") {
dp[i][j] = dp[i + 1][j] || dp[i][j + 1]
} else {
dp[i][j] = false
}
}
}
return dp[0][0]
};
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- PowerShell转义通配符
- Wildpwn:Unix通配符攻击工具
- Java 泛型之上界下界通配符
- 004-零失败快速搞定通配符SSL证书
- PHP源码调试之Windows文件通配符分析
- 正则表达式 – Morphia mongoDB通配符查询
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Hit Refresh
Satya Nadella、Greg Shaw / HarperBusiness / 2017-9-26 / USD 20.37
Hit Refresh is about individual change, about the transformation happening inside of Microsoft and the technology that will soon impact all of our lives—the arrival of the most exciting and disruptive......一起来看看 《Hit Refresh》 这本书的介绍吧!