首页 > 解决方案 > 用正则表达式解析(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

标签: javaregex

解决方案


您的模式有多余的捕获组,并重复 2 个捕获组,这将捕获最后一次迭代的值。

\+*,*将允许尾随加号和逗号。


一种选择是使用 2 个捕获组和模式的展开形式来匹配示例字符串的数据格式,可选择重复前面的相同模式,+以防止允许尾随+,

在代码中,您可以检查第 1 组和第 2 组的值并使用 split 来获取单独的部分。

图案稍长

\(\[(Modulus\(\d+\)(?:\s*,\s*Modulus\(\d+\))*)\]\):(\(\d+(?:,\d+)*\)x\^\d+(?:\s*\+\s*\(\d+(?:,\d+)*\)x\^\d+)*)

查看正则表达式演示Java 演示

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

正则表达式演示


推荐阅读