关于delete实例运用的问题

qaswe 2008-04-15 07:27:14
-----------------------------------------------
//我希望通过下面的程序来实现杨辉三角的输出
#include<iostream>
using namespace std;
int main(void){
int n,j,i;
int *p=new int;
int *q;
p[0]=1;
cin>>n;
cout<<1<<endl;
if (n>1) for(i=2;i<=n;i++)
{
q=new int(i);
for(j=1;j<=i;j++){

if (j==1) {q[0]=1;cout<<1<<" ";}
else if (j==i) {q[i-1]=1;cout<<1<<endl;}
else {
q[j-1]=p[j-2]+p[j-1];
cout<<q[j-1]<<" ";}
}
delete []p; //为什么系统运行这句时出现错误?
p=q;
}
delete[]p;
return 0;
}



...全文
50 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
yshuise 2008-04-19
  • 打赏
  • 举报
回复
q=new int(i);

这只构造了一个对象。
申请数组对象是 q = new int[i]
帅得不敢出门 2008-04-19
  • 打赏
  • 举报
回复
q=new int(i);
这个也有问题啊 只申请了一个int 空间 而你后面访问越界了
应该是q = new int[i];
mengde007 2008-04-19
  • 打赏
  • 举报
回复
你的定义里面只有INT *P;再也没有了P的信息,突然又有了P[I];我不知道从哪儿来的
qaswe 2008-04-15
  • 打赏
  • 举报
回复
o~~~
明白了,原来是括号用错了........倒....
独孤过儿 2008-04-15
  • 打赏
  • 举报
回复
当申请的对象内存大于一个的时候,采用delete [] p;,像这样

int *ptr = new int[10];
delete [] ptr;
独孤过儿 2008-04-15
  • 打赏
  • 举报
回复
delete p;

64,654

社区成员

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

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