各位大神帮忙看看:这个程序里面的析构函数怎么回事???怎么提前析构了???
#include<iostream>
using namespace std;
class Duo_xiang_shi
{
private:
int n;
int * p;
public:
static int count;
Duo_xiang_shi();
Duo_xiang_shi(int n);
Duo_xiang_shi(const &Duo_xiang_shi);
~Duo_xiang_shi();
void input();
void output();
void calculate(int x);
Duo_xiang_shi operator+(const Duo_xiang_shi & dxs);
Duo_xiang_shi operator*(const Duo_xiang_shi & dxs);
Duo_xiang_shi operator-(const Duo_xiang_shi & dxs);
Duo_xiang_shi operator=(const Duo_xiang_shi & dxs);
};
Duo_xiang_shi::Duo_xiang_shi()
{
n=0;
p=new int[n];
p[0]='\0';
count++;
}
Duo_xiang_shi::Duo_xiang_shi(int n)
{
count++;
p=new int [n];
}
Duo_xiang_shi::~Duo_xiang_shi()
{
delete [] p;
}
void Duo_xiang_shi::input()
{
cout<<"请输入多项式的最大指数:"<<endl;
cin>>n;
while(!cin)
{
cin.clear();
while (cin.get() !='\n')
continue;
cout<<"输入错误,请重新再输入:"<<endl;
continue;
}
p=new int[n+1];
cout<<"请从低到高输入多项式的系数:";
for(int i=0;i<n+1;i++)
{
cin>>*(p+i);
if(!cin)
{
cin.clear();
while (cin.get() !='\n')
continue;
cout<<"输入错误,请重新输入:";
break;
}
}
}
void Duo_xiang_shi::output()
{
cout<<"多项式按指数从大到小输出为:"<<endl;
cout<<p[n]<<"x^"<<n;
for(int i=n-1;i>=1;i--)
{
if(p[i]!=0)
cout<<"+"<<p[i]<<"x^"<<i;
else continue;
}
if(p[0]!=0)
cout<<"+"<<p[0];
cout<<endl;
}
void Duo_xiang_shi::calculate(int y)
{
int ans=*(p+n-1);
for(int i=n-2;i>=0;i--){
ans*=y;
ans+=(*(p+i));
}
cout<<ans;
}
Duo_xiang_shi Duo_xiang_shi::operator+(const Duo_xiang_shi & dxs)
{
Duo_xiang_shi Sum;
int Max_n = n>dxs.n ?n:dxs.n;
int Min_n = n<dxs.n ?n:dxs.n;
Sum.n = Max_n;
Sum.p = new int[Sum.n + 1];
if (dxs.n == Max_n)
{
for (int i = 0; i<dxs.n+ 1; i++)
Sum.p[i] = dxs.p[i];
}
else {
for (int i = 0; i<n+ 1; i++)
Sum.p[i] = p[i];
}
for (int i = 0; i<Min_n + 1; i++)
Sum.p[i] = p[i] + dxs.p[i];
return Sum;
}
Duo_xiang_shi Duo_xiang_shi::operator-(const Duo_xiang_shi & dxs)
{
Duo_xiang_shi dif;
int Max_n = n>dxs.n ? n : dxs.n;
int Min_n = n<dxs.n ? n : dxs.n;
dif.n = Max_n;
dif.p = new int[dif.n + 1];
if (dxs.n == Max_n)
{
for (int i = 0; i<Max_n + 1; i++)
dif.p[i] = dxs.p[i];
}
else {
for (int i = 0; i<Max_n + 1; i++)
dif.p[i] = p[i];
}
for (int i = 0; i<Min_n + 1; i++)
dif.p[i] = p[i] - dxs.p[i];
return dif;
}
Duo_xiang_shi Duo_xiang_shi::operator*(const Duo_xiang_shi &dxs)
{
Duo_xiang_shi multiply;
multiply.n=n*dxs.n;
multiply.p=new int[multiply.n+1];
if(n>dxs.n)
{
for(int i=0;i<n+1;i++)
for(int j=0;j<dxs.n+1;j++)
multiply.p[i]=p[i]*dxs.p[j];
}
else for(int i=0;i<dxs.n+1;i++)
for(int j=0;j<n+1;j++)
multiply.p[i]=p[j]*dxs.p[i];
return multiply;
}
Duo_xiang_shi Duo_xiang_shi::operator=(const Duo_xiang_shi & dxs)
{
if(this==&dxs)
return *this;
delete [] p;
p=new int[dxs.n+1];
for(int i=0;i<dxs.n+1;i++)
p[i]=dxs.p[i];
return *this;
}
int Duo_xiang_shi::count=0;
int main()
{
int n1,n2,y1,y2;
Duo_xiang_shi d1,d2,d3,d4,d5,d6;
d1.input();
cout<<"多项式1:"<<endl;
d1.output();
d2.input();
cout<<"多项式2:"<<endl;
d2.output();
cout<<"多项式1+2="<<endl;
d3=d1+d2;
d3.output();
cout<<"多项式1-2="<<endl;
d4=d1-d2;
d4.output();
cout<<"多项式1*2="<<endl;
d5=d1*d2;
d5.output();
cout<<"请按照提示输入一个多项式给多项式1实现赋值运算:"<<endl;
d6.input();
d1=d6;
cout<<"d1="<<endl;
d1.output();
return 0;
}