java - 用正则表达式解析(RNS)多项式
问题描述
我正在尝试编写一个正则表达式来解析 RNS(残数系统)形式的多项式:
RNS Polynomial ([Modulus(68719403009), Modulus(68719230977), Modulus(137438822401)]): (67699591241,42814670386,92925202514)x^0 + (42539574637,55054036653,135659663247)x^1 + (52858091297,11618896202,6855552742)x^2 + (45970532823,20845087073,91272562929)x^3 + (11148839321,55275439733,5401722690)x^4 + (31959765643,40620395732,93052536121)x^5 + (57030732406,66026147059,6304524013)x^6 + (27778918692,11276356856,61606736382)x^7
我写:
\(\[(Modulus\(\d+\)(,*)\s*)+\]\):(\s*\((\d*,*)+\)x\^\d\s*\+*)+
但我只能完全解析它。我不能有一个组,Modulus
系数也没有(a,b,c,...)x^n
。怎么了?
这是 regex101:https ://regex101.com/r/itBQHJ/1
解决方案
您的模式有多余的捕获组,并重复 2 个捕获组,这将捕获最后一次迭代的值。
这\+*
也,*
将允许尾随加号和逗号。
一种选择是使用 2 个捕获组和模式的展开形式来匹配示例字符串的数据格式,可选择重复前面的相同模式,
或+
以防止允许尾随+
和,
在代码中,您可以检查第 1 组和第 2 组的值并使用 split 来获取单独的部分。
图案稍长
\(\[(Modulus\(\d+\)(?:\s*,\s*Modulus\(\d+\))*)\]\):(\(\d+(?:,\d+)*\)x\^\d+(?:\s*\+\s*\(\d+(?:,\d+)*\)x\^\d+)*)
Java中的一个例子
String regex = "\\(\\[(Modulus\\(\\d+\\)(?:\\s*,\\s*Modulus\\(\\d+\\))*)\\]\\):(\\(\\d+(?:,\\d+)*\\)x\\^\\d+(?:\\s*\\+\\s*\\(\\d+(?:,\\d+)*\\)x\\^\\d+)*)";
String string = "RNS Polynomial ([Modulus(68719403009), Modulus(68719230977), Modulus(137438822401)]):(67699591241,42814670386,92925202514)x^0 + (42539574637,55054036653,135659663247)x^1 + (52858091297,11618896202,6855552742)x^2 + (45970532823,20845087073,91272562929)x^3 + (11148839321,55275439733,5401722690)x^4 + (31959765643,40620395732,93052536121)x^5 + (57030732406,66026147059,6304524013)x^6 + (27778918692,11276356856,61606736382)x^7\n";
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(string);
while (matcher.find()) {
if (matcher.group(1) != null) {
for (String elm1 : matcher.group(1).split(",\\s*"))
System.out.println(elm1);
}
if (matcher.group(2) != null) {
for (String elm2 : matcher.group(2).split("\\s*\\+\\s*"))
System.out.println(elm2);
}
}
输出
Modulus(68719403009)
Modulus(68719230977)
Modulus(137438822401)
(67699591241,42814670386,92925202514)x^0
(42539574637,55054036653,135659663247)x^1
(52858091297,11618896202,6855552742)x^2
(45970532823,20845087073,91272562929)x^3
(11148839321,55275439733,5401722690)x^4
(31959765643,40620395732,93052536121)x^5
(57030732406,66026147059,6304524013)x^6
(27778918692,11276356856,61606736382)x^7
另一种模式可能是使用交替|
来匹配字符串的两个特定部分,但它不会验证整个数据结构。
\b(Modulus\(\d+\))|(\(\d+(?:,\d+)*\)x\^\d+)\b
推荐阅读
- css - Visual Studio 代码编辑器在我的 sass 代码中显示错误(代码下方的红线)
- java - spring boot junit mockito 空指针异常
- javascript - 动画仅适用于第一次单击按钮
- android - 在 Recycler View View-Holder 中暂停函数
- javascript - 如何在nuxt js中用jest测试其他条件?
- json - 将 OData 转换为 JSON 以用于 Elasticsearch
- html - 将 HTML 输出嵌入 Jenkins 仪表板
- node.js - 有什么方法可以修复 node js bug 而无需重新安装 windows?
- javascript - 如何在 ExtJS 7 中自定义材质主题的暗模式 - 经典
- html - 如何在 yml 文件的导航栏上方添加一张图片?