求大神按照要求用c++帮我解决

24.设计多项式类Polynomial,实现两多项式相加。具体要求如下:
(1)私有数据成员
·double a[10][2]; 存放多项式,包含一个系数和一个指数。例如:2X4的系数为2,指数为4。
·int n; 存放多项式的项数
(2)公有成员函数
·Polynomial (double b[][2],int x) ; 定义构造函数,给私有数据成员初始化。
·Polynomial operator + (Polynomial); 重载运算符+,实现两个多项式相加。
·Polynomial operator += (Polynomial &); 重载运算符+=,实现两个多项式相加赋值。
·Polynomial operator = (Polynomial &); 重载运算符=,实现多项式赋值。
·void print(); 输出多项式。
(3)在主函数中完成对Polynomial类的测试。

该回答引用ChatGPT-3.5

下面是按照您的要求使用C++实现的Polynomial类及其成员函数:

#include <iostream>

class Polynomial {
private:
    double a[10][2];
    int n;

public:
    Polynomial(double b[][2], int x) {
        n = x;
        for (int i = 0; i < n; i++) {
            a[i][0] = b[i][0];
            a[i][1] = b[i][1];
        }
    }

    Polynomial operator+(Polynomial poly) {
        Polynomial result(*this);
        int i, j, k;
        i = j = k = 0;

        while (i < n && j < poly.n) {
            if (a[i][1] > poly.a[j][1]) {
                result.a[k][0] = a[i][0];
                result.a[k][1] = a[i][1];
                i++;
            } else if (a[i][1] < poly.a[j][1]) {
                result.a[k][0] = poly.a[j][0];
                result.a[k][1] = poly.a[j][1];
                j++;
            } else {
                result.a[k][0] = a[i][0] + poly.a[j][0];
                result.a[k][1] = a[i][1];
                i++;
                j++;
            }
            k++;
        }

        while (i < n) {
            result.a[k][0] = a[i][0];
            result.a[k][1] = a[i][1];
            i++;
            k++;
        }

        while (j < poly.n) {
            result.a[k][0] = poly.a[j][0];
            result.a[k][1] = poly.a[j][1];
            j++;
            k++;
        }

        result.n = k;
        return result;
    }

    Polynomial operator+=(Polynomial& poly) {
        *this = *this + poly;
        return *this;
    }

    Polynomial operator=(Polynomial& poly) {
        n = poly.n;
        for (int i = 0; i < n; i++) {
            a[i][0] = poly.a[i][0];
            a[i][1] = poly.a[i][1];
        }
        return *this;
    }

    void print() {
        for (int i = 0; i < n; i++) {
            std::cout << a[i][0] << "X^" << a[i][1];
            if (i != n - 1) {
                std::cout << " + ";
            }
        }
        std::cout << std::endl;
    }
};

int main() {
    double poly1[3][2] = { {2, 4}, {3, 2}, {1, 0} };
    double poly2[4][2] = { {1, 3}, {-2, 2}, {4, 1}, {5, 0} };

    Polynomial p1(poly1, 3);
    Polynomial p2(poly2, 4);

    Polynomial p3 = p1 + p2;
    p3.print();

    p1 += p2;
    p1.print();

    Polynomial p4 = p2;
    p4.print();

    return 0;
}

这段代码实现了Polynomial类,其中构造函数Polynomial(double b[][2], int x)用于初始化多项式的私有数据成员,operator+重载了加法运算符用于两个


多项式的相加,operator+=重载了加等运算符用于两个多项式相加并赋值,operator=重载了赋值运算符用于多项式的赋值,print函数用于输出多项式。


在主函数中,我们创建了两个多项式p1p2,并进行了测试,输出了相加后的多项式以及使用+=运算符进行相加赋值后的结果。


请注意,这段代码中假设每个多项式的最大项数为10,可以根据需要进行调整。同时,未在代码中进行输入验证,假设输入的多项式数据格式正确。