各位大神帮忙看看:这个程序里面的析构函数怎么回事???怎么提前析构了???

Small_handsome 2018-05-19 03:35:54
#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;
}
...全文
808 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2018-05-21
  • 打赏
  • 举报
回复
理解讨论之前请先学会如何观察! 计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构…… 对学习编程者的忠告: 多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程! 眼过千遍不如手过一遍! 书看千行不如手敲一行! 手敲千行不如单步一行! 单步源代码千行不如单步Debug版对应汇编一行! 单步Debug版对应汇编千行不如单步Release版对应汇编一行! 不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建所有,然后在IDE中运行。(一般人我不告诉他!单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。 VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。 对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
冷风1023 2018-05-19
  • 打赏
  • 举报
回复
没有看明白楼主想要问什么,能详细点吗?哪里提前析构了?

64,646

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧