news 2026/6/22 21:40:51

- - - 正则表达式匹配 diff - - -

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
- - - 正则表达式匹配 diff - - -

题目要求是给一个字符串和一个表达式字符串,要让表达式字符串通过给定的规则,完全的匹配字符串,俩个字符串中的所有字符都要使用到

对于给的这个字符串规则,有几点重要

. 是必须要匹配一个字符 aa ... 是匹配不上的

* 这个字符前面一定会有一个字符,他不会单独出现,也不会位于字符首

a* 可以匹配空字符串,也就是说 ab c*ab 也是能匹配上的

.* 他能被翻译 ....... 若干个点也就是可以匹配任意的字符串

那么现在就可以着手开始解这道题了

对于 s 字符串 p 表达式字符串 他俩的匹配

前面的mis都是相同的,而到第一个*时,发现*前面时s 于是s*可以翻译为 空 s ss sss 等,而这些情况是都需要储存下来的,因为*后面的s 是需要找到一个 s* 翻译为 ssss 这个字符串,才能正确的匹配字符串,而我再走到s*翻译时,并不会知道后面的字符串时需要翻译为哪个才能正确表示

所以需要全部储存下来,而这样就有了一个表达式

到p位置的字符串能否翻译 = p 位置 和 s 位置相同 && p 位置之前的字符串 和 s 位置 之前的字符串能匹配上

很容易看出了,动态规划解法,而且需要一个二维的dp表,表示p s字符串的位置,用dp来表示俩字符串的匹配关系

那么dp表定义就有了 dp[m][n] 表示0 - m 长度的字符串 和 0 - n 长度的匹配字符串能否匹配上

比如 dp[2][3] = true 表示 长度为 0 - 2 的 s 字符串 和 长度为 0- 3 的匹配字符串能匹配上

状态方程的推导

整理下 最终的推导方程

初始化

首先多一行多一列防止越界

对边界特殊处理

0 0 位置俩都为空可以被匹配 所以 dp[0][0] = true

dp[x][0] 表示表达式字符串为空 那么一个都匹配不上,所以全为false

dp[0] 表示需要匹配的字符串为空 应为有 a* 这种在 它可以表示空 所以需要给特殊处理为为true

dp[0][2] = true p[0-1] 能翻译为空

dp[0][4] = true p[0-1] 为空 p[2 - 3] 为空

之后越界了 不过如果不为* 就退出处理,因为之后的都匹配不上空的s字符串了

到这就可以开始些代码了

public boolean isMatch1(String ss, String pp) { char[] s = ss.toCharArray(); char[] p = pp.toCharArray(); int m = s.length; int n = p.length; // m 表示 字符串 n 规则 boolean[][] dp = new boolean[m + 1][n + 1]; //只有. 会涉及到 i-1 j-1 dp[0][0] = true; //初始化 因为 a8 可以翻译为空字符串 所以需要特殊处理开头 for(int i = 2; i < n + 1; i += 2){ if(p[i - 1] == '*') dp[0][i] = true; else break; } for(int i = 1; i < m + 1; i++){ for(int j = 1; j < n + 1; j++){ char curS = s[i - 1]; char curP = p[j - 1]; if(curP == '.' || curS == curP){ dp[i][j] = dp[i - 1][j - 1]; }else if(curP == '*'){ dp[i][j] = dp[i][j - 2] || (p[j - 2] == curS || p[j - 2] == '.') && dp[i - 1][j]; } } } return dp[m][n]; }

wok 写了3小时+ 这真是我做过的最难的动态规划题 且时最难的递归题

挺有意思的 尤其是最后的为空的特殊处理,给我迷了好一会

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 16:43:58

Kotaemon支持PDF/PPT/Word等多种文档解析

Kotaemon&#xff1a;让企业文档真正“活”起来的智能解析框架 在当今企业环境中&#xff0c;知识不再只是数据库里的结构化字段&#xff0c;而是深藏于成千上万份PDF报告、PPT演示和Word文档中的非结构化信息。这些文件每天都在增长——年度财报、产品手册、会议纪要、合规政策…

作者头像 李华
网站建设 2026/6/21 14:11:28

Kotaemon在制造业知识管理中的创新应用案例

Kotaemon在制造业知识管理中的创新应用 在现代工厂的车间里&#xff0c;一台数控机床突然停机&#xff0c;屏幕上跳出一串故障代码。一线工程师拿起平板电脑&#xff0c;用语音问道&#xff1a;“PLC报警E501是什么意思&#xff1f;”不到三秒&#xff0c;系统不仅给出了诊断解…

作者头像 李华
网站建设 2026/6/17 15:51:33

Kotaemon配置文件全参数说明,新手必看!

Kotaemon配置文件全参数说明&#xff0c;新手必看&#xff01; 在构建智能对话系统时&#xff0c;很多开发者都曾面临这样的困境&#xff1a;模型明明训练得不错&#xff0c;生成的回答却总是“答非所问”或“一本正经地胡说八道”。尤其是在企业级场景中&#xff0c;知识准确…

作者头像 李华
网站建设 2026/6/22 22:07:42

EmotiVoice语音合成结果的跨设备播放一致性测试

EmotiVoice语音合成结果的跨设备播放一致性测试 在智能语音助手、虚拟偶像直播和游戏NPC对话日益普及的今天&#xff0c;用户早已不再满足于“能听清”的机械朗读。他们期待的是有情感、有个性、仿佛真实存在的人声表达。EmotiVoice作为一款开源多情感TTS引擎&#xff0c;凭借其…

作者头像 李华
网站建设 2026/6/14 13:22:20

EmotiVoice语音合成安全性分析:防止恶意声音克隆的机制

EmotiVoice语音合成安全性分析&#xff1a;防止恶意声音克隆的机制 在虚拟偶像直播中突然听到“明星”亲自呼吁投资某项目&#xff0c;或是接到一段听起来与亲人一模一样的求救电话——这些曾出现在科幻电影中的桥段&#xff0c;正随着语音合成技术的进步逐渐成为现实威胁。Emo…

作者头像 李华
网站建设 2026/6/23 0:54:27

rrweb 原理:基于 DOM 变动(MutationObserver)的会话录制与回放

rrweb 原理详解:基于 DOM 变动的会话录制与回放技术解析 各位开发者朋友,大家好!今天我们来深入探讨一个在前端监控领域非常热门的技术——rrweb(Record Replayer Web)。它是一个开源项目,能够对用户在网页上的操作行为进行完整记录,并支持后续的回放。这项能力对于调试…

作者头像 李华