Итак, я разработал полиномиальный класс, в котором вводимые пользователем данные: 1x ^ 0 + 2x ^ 1 + 3x ^ 2 ... и 1,2,3 (коэффициенты) хранятся в массиве int
Мои перегруженные функции + и - работают, однако * не работают. Независимо от ввода, он всегда показывает -842150450
когда должно быть (5x ^ 0 + x ^ 1) * (-3x ^ 0 + x ^ 1) = -15x ^ 0 + 2x ^ 1 + 1x ^ 2
или (х + 5) (х-3) = х ^ 2 + 2х - 15
Я использую перегруженную * функцию, например: Polynomial multiply = one * two;
Я предполагаю, что проблема в strtol (p, & endptr, 10), так как он использует длинное целое, однако сложение и вычитание работает отлично
Мой конструктор
Polynomial::Polynomial(char *s)
{
char *string;
string = new char [strlen(s) + 1];
int length = strlen(string);
strcpy(string, s);
char *copy;
copy = new char [length];
strcpy(copy, string);
char *p = strtok(string, " +-");
counter = 0;
while (p)
{
p = strtok(NULL, " +-");
counter++;
}
coefficient = new int[counter];
p = strtok(copy, " +");
int a = 0;
while (p)
{
long int coeff;
char *endptr;
coeff = strtol(p, &endptr, 10); //stops at first non number
if (*p == 'x')
coeff = 1;
coefficient[a] = coeff;
p = strtok(NULL, " +");
a++;
}
}
и перегруженная * функция
Polynomial Polynomial::operator * (const Polynomial &right)
{
Polynomial temp;
//make coefficient array
int count = (counter + right.counter) - 1;
temp.counter = count;
temp.coefficient = new int [count];
for (int i = 0; i < counter; i++)
{
for (int j = 0; j < right.counter; j++)
temp.coefficient[i+j] += coefficient[i] * right.coefficient[j];
}
return temp;
}
И вот весь мой код: http://pastie.org/721143