news 2026/4/15 20:50:01

- - - 正则表达式匹配 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/4/12 16:17:08

Kotaemon支持GraphQL查询外部数据源

Kotaemon支持GraphQL查询外部数据源 在企业级智能对话系统日益复杂的今天&#xff0c;一个核心挑战浮出水面&#xff1a;如何让AI代理不仅“知道”知识&#xff0c;还能实时“访问”动态业务数据&#xff1f;传统的RAG&#xff08;检索增强生成&#xff09;系统大多依赖静态文档…

作者头像 李华
网站建设 2026/4/15 14:51:00

EmotiVoice语音合成系统的响应时间优化方案

EmotiVoice语音合成系统的响应时间优化方案 在实时语音交互场景中&#xff0c;用户对“即时反馈”的期待早已超越了简单的功能实现。当你对着智能助手说出一句话&#xff0c;等待超过1秒才听到回应&#xff0c;那种迟滞感就会悄然破坏沉浸体验。这种延迟背后&#xff0c;往往是…

作者头像 李华
网站建设 2026/4/14 17:18:36

AST反混淆插件|去控制流前对运算符的简化操作

关注它&#xff0c;不迷路。本文章中所有内容仅供学习交流&#xff0c;不可用于任何商业用途和非法用途&#xff0c;否则后果自负&#xff0c;如有侵权&#xff0c;请联系作者立即删除&#xff01;1.还原场景为使用九大节点合并算法工具做的一些准备工作。2.遍历的节点类型&quo…

作者头像 李华
网站建设 2026/4/15 14:48:06

EmotiVoice语音合成在盲文图书配套音频中的公益价值

EmotiVoice语音合成在盲文图书配套音频中的公益价值 在一间安静的图书馆角落&#xff0c;一位视障学生正用指尖轻抚盲文页面&#xff0c;逐字阅读一本文学作品。尽管他能理解文字含义&#xff0c;但那些潜藏于语调起伏与节奏变化中的情感色彩——喜悦、悲伤、紧张或幽默——却难…

作者头像 李华
网站建设 2026/4/15 14:49:41

EmotiVoice如何实现沙哑、疲惫等特殊状态语音?

EmotiVoice如何实现沙哑、疲惫等特殊状态语音&#xff1f; 在虚拟偶像直播中突然“感冒”&#xff0c;游戏主角受伤后声音嘶哑&#xff0c;语音助手深夜轻声细语仿佛困倦欲睡——这些不再是影视特效&#xff0c;而是如今通过 EmotiVoice 这类高表现力TTS系统即可实现的真实语音…

作者头像 李华
网站建设 2026/4/6 15:47:52

BroadcastChannel API:实现跨 Tab 页的数据库变更通知

BroadcastChannel API:实现跨 Tab 页的数据库变更通知(讲座式技术文章) 各位开发者朋友,大家好!今天我们来深入探讨一个在现代 Web 应用中非常实用但常被忽视的技术点:如何利用 BroadcastChannel API 实现跨 Tab 页的数据库变更通知。 这不仅是一个“能用”的功能,更是…

作者头像 李华