万能的 v 友,带与或的字符串规则库的匹配应该用什么算法?求推荐 java 版。

2016-07-18 22:33:54 +08:00
 nbabook

我这边的需求是要匹配规则集中的任一条,例如规则 = 『 abc && efg || 12uiksfd 』,待匹配的字符串 = 『 1287abcdfdaefgdogkaddgd 』; 规则集的规模差不多在 1 万左右的规模。 常规的多模匹配算法,例如 AC 、 WM ,好像不能做这种带与或规则的匹配。 不知道万能的 v 友有什么推荐?最好是 java 版的。 辛苦辛苦。。。

1154 次点击
所在节点    问与答
2 条回复
mx1700
2016-07-19 07:37:38 +08:00
把规则解析成普通字符串,然后在用 AC 查找
h4x3rotab
2016-07-19 20:02:39 +08:00
如何把规则解析成普通字符串?我没想到对于 and or 表达式这种可行的办法。

我的想法是先把所有规则里的字符串独立取出来,编号之后插入 ac 自动机,然后用 ac 匹配。每个输入串匹配之后都可以得到规则里字符串的编号。最后用编号和对应规则做一个 dfs ,或者对规则做倒排,就可以在 O(m+n)的时间里解决问题。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/293325

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX