std::regex来识别多项式方程的系数

std::regex to identify coefficient of polynomial equation

本文关键字:方程 识别 regex std 多项式      更新时间:2023-10-16

我是C++新手,我被要求创建一个二阶多项式函数的求解器。为此,我首先需要解析方程并将其简化以简化形式显示它,即:

8 * X^0 - 6 * X^1 + 5.6 * X^2 = 3 * X^0 成为 5 * X^0 - 6 * X^1 + 5.6 * X^2 = 0

经过几个小时的查看不同的语法,我发现以下正则表达式[0-9]+(?=.?[*](?=.?(?=(X^0))))83标识为系数(仍然需要处理负号)。

我的问题是,以下带有库<regex>的代码似乎没有给我83而是整个等式,我想知道为什么?因为代码在正则表达式在线测试器中作为full match 1full match 2工作。我想知道这是否不是因为我也有有点搞砸的团体。

#include <iostream>
#include <regex>
using namespace std;
int main()
{
    string var = "8 * X^0 - 6 * X^1 + 5.6 * X^2 = 3 * X^0";
    regex wsaq_re("[-](?=.?[0-9](?=.?[*](?=.?(?=(X^0)))))"); 
    copy( sregex_token_iterator(var.begin(), var.end(), wsaq_re, -1),
        sregex_token_iterator(),
        ostream_iterator<string>(cout, "n"));
    return 0;
}

创建正则表达式迭代器时:

sregex_token_iterator(var.begin(), var.end(), wsaq_re, -1)

-1 作为第三个参数表示

子匹配 - 应返回的子匹配项的索引。"0" 表示整个匹配项,"-1"表示 不匹配(例如,匹配之间的内容)。

你应该把 1 放在那里。

恕我直言,您的正则表达式也过于复杂,这个应该足够了:

regex wsaq_re( "(=?\s*\-?\s*\d+\s*\*\s*X\s*\^\d+)");

现场演示输出为:

8 * X^0
- 6 * X^1
6 * X^2
= 3 * X^0