读多项式

时间:2016-03-29 19:51:20

标签: c++ struct compilation polynomial-math

嗨我在阅读我创建的多项式时遇到了问题。我必须实现一些操作,但我在阅读阶段有问题,我没有找到任何解决方案。 错误是:

||=== Build: Debug in Big HW (compiler: GNU GCC Compiler) ===|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp||In instantiation of 'void Polynomial<T>::readP() [with T = int]':|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|58|required from here|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|31|error: no matching function for call to 'Queue<int>::enqueue(term&)'|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|31|note: candidate is:|
C:\Facultate Personal\DSA\Big HW\queue.h|17|note: void Queue<T>::enqueue(T) [with T = int]|
C:\Facultate Personal\DSA\Big HW\queue.h|17|note:   no known conversion for argument 1 from 'term' to 'int'|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp||In instantiation of 'void Polynomial<T>::invert() [with T = int]':|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|59|required from here|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|50|error: no match for 'operator[]' (operand types are 'Queue<int>' and 'int')|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|50|error: no match for 'operator[]' (operand types are 'Queue<int>' and 'int')|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp||In instantiation of 'void Polynomial<T>::computeX(T) [with T = int]':|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|60|required from here|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|42|error: no match for 'operator[]' (operand types are 'Queue<int>' and 'int')|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|42|error: no match for 'operator[]' (operand types are 'Queue<int>' and 'int')|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|42|error: no match for 'operator[]' (operand types are 'Stack<int>' and 'int')|
C:\Facultate Personal\DSA\Big HW\big_hw.cpp|42|error: no match for 'operator[]' (operand types are 'Stack<int>' and 'int')|
||=== Build failed: 7 error(s), 6 warning(s) (0 minute(s), 0 second(s)) ===|

读取功能和主要:

#include <iostream>
#include <math.h>
#include "queue.h"
#include "stack.h"
using namespace std;

struct term{
int coef;
int expo;};

template<typename T> class Polynomial{
private:
T coef;
T expo;
public:
Queue<T> polin;
int n;
struct term *p;


Polynomial(){}
~Polynomial(){}

void readP()
{
    cout<<"Please insert the maximum grade of the polynomial: "; cin>>n;
    for(int i=0;i<=n;i++)
    {
        cout<<"Please insert the coefficient for x^"<<(n-i)<<": "; cin>>p[i].coef;
        p[i].expo=n-i;
        polin.enqueue(p[i]);

    }
    cout<<endl;
}
};
int main()
{
Polynomial<int> polin;
polin.readP();
polin.invert();
polin.computeX(2);
return 0;
}

入队功能是:

void enqueue(T x) {
        if (size >= NMAX) {
            cout << "The queue is FULL" << endl;
            return;
        }

        queueArray[tail] = x;
        tail=(tail+1)%NMAX;
        size--;
    }

我做错了什么?

1 个答案:

答案 0 :(得分:0)

错误非常自我解释:

error: no matching function for call to 'Queue<int>::enqueue(term&)

您将一个术语对象传递给enqueue函数,该函数需要T(= int)。也许你打算通过p[i].coefp[i].expo

error: no match for 'operator[]' (operand types are 'Queue<int>' and 'int')

看起来Queue没有索引操作符。

修改

我也发现了别的东西。当您阅读term时,您将它们放入struct term *p变量,但使用p[i]访问它。这意味着,如果我&gt; 0你处于未定义的行为领域。

我的建议是摆脱p变量并写下你的for循环:

for (int i = 0; i <= n; i++)
{
    term t;

    std::cout << "Please insert the coefficient for x^" << (n - i) << ": ";
    std::cin >> t.coef;
    t.expo = n - i;

    polin.enqueue(t);
}