node* CreatList(int num)//创建链表数 { node *head, *p1, *p2; head = new node; //head被初始化了吗? 50

//要求是创建一个链表函数,每个结点记录一个数据,记录N个,返回链表;p2=p1=head;for(inti=0;i<num;i++){cin>>p1->data;p1=... //要求是创建一个链表函数,每个结点记录一个数据,记录N个,返回链表;

p2 = p1 = head;

for(int i = 0; i < num; i++)
{

cin>>p1->data;
p1 = new node;//新建一个链接

p2->next = p1;
p2 = p1;
}
return head;
}
我不知道错在哪里。求帮忙
展开
 我来答
风若远去何人留
2016-09-05 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450131
专业C/C++软件开发

向TA提问 私信TA
展开全部

p1申请的晚了。

应该是先申请 再输入。

p2 = head;//这里p2就可以了。 p1没必要。

for(int i = 0; i < num; i++)
{
                p1 = new node;//先申请内存 或者说 创建对象
cin>>p1->data;
p1->next=NULL; //这个最好加上。当然 如果在node构造里面已经有了,就不用了。
p2->next = p1;
p2 = p1;
}
return head;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式