[44] 通配符匹配

和第十题很相似,当时第十题使用js写的直接就挪过来了,这道题当初用java写的,在转为js时又重新整理了一下逻辑。思路图解的话可以参考这篇文章:https://blog.51cto.com/u_15067267/3677200
复制代码
 1 /**
 2  * @param {string} s
 3  * @param {string} p
 4  * @return {boolean}
 5  */
 6 var isMatch = function(s, p) {
 7   const xLen = s.length;
 8   const yLen = p.length;
 9   // 建立一个二维数组
10   const dp = Array.from(Array(yLen + 1), () => new Array(xLen + 1).fill(false));
11   dp[0][0] = true;
12   for (let i = 1; i <= yLen; i++) {
13     if (p[i - 1] === '*') {
14       dp[i][0] = true;
15     } else {
16       break;
17     }
18   }
19   for (let i = 1; i <= yLen; i++) {
20     for (let j = 1; j <= xLen; j++) {
21       if (p[i - 1] == '*') {
22         dp[i][j] = dp[i][j - 1] || dp[i - 1][j];
23       } else if (p[i - 1] === '?' || s[j - 1] === p[i - 1]) {
24         dp[i][j] = dp[i - 1][j - 1];
25       }
26     }
27 
28   }
29   return dp[yLen][xLen];
30 
31 };
复制代码

 

posted @   人恒过  阅读(7)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本

阅读目录(Content)

此页目录为空

点击右上角即可分享
微信分享提示