| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 258 人关注过本帖
标题:这个链表输出时为啥又是内存错误,到底是哪出了问题啊?求解。。。
只看楼主 加入收藏
木偶然
Rank: 2
等 级:论坛游民
帖 子:29
专家分:22
注 册:2011-6-12
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:2 
这个链表输出时为啥又是内存错误,到底是哪出了问题啊?求解。。。
#include <stdio.h>
#include <stdlib.h>
#include "windows.h"
struct node
{
 int num;
 struct node *next;
};
int main()
{
 struct node *p,*q,*head;
 struct node node1;
 p=q=(struct node *)malloc(sizeof(struct node));
 printf("请输入链表:\n");
 scanf("%d",&node1.num);
 int n=0;
 while(node1.num!=0)
 {
  n++;
  if(n==1)
  {
   head=p;
   p->next=NULL;
  }
  else
  {
   q->next=p;

  }
  q=p;
  p=(struct node *)malloc(sizeof(struct node));
  scanf("%d",&node1.num);
 }
 printf("按任意键输出链表!\n");
 system("pause");
 struct node *r;
 r=head;
 if(head!=NULL)
 do
 {
  printf("%d\n",r->num);
  r=r->next;
 }
 while(r->next!=NULL);
 return 0;
}

图片附件: 游客没有浏览图片的权限,请 登录注册


[ 本帖最后由 木偶然 于 2011-6-16 21:59 编辑 ]
2011-06-16 21:57
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:20 
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include "windows.h"
struct node
{
int num;
struct node *next;
};
int main()
{
struct node *p,*q,*head;
struct node node1;
p=q=(struct node *)malloc(sizeof(struct node));
p->next = NULL;
printf("请输入链表:\n");
scanf("%d",&p->num);
int n=0;
while(p->num!=0)
{
  n++;
  if(n==1)
  {
   head=p;
   p->next=NULL;
  }
  else
  {
   q->next=p;

  }
  q=p;
  p=(struct node *)malloc(sizeof(struct node));
  p->next = NULL;
  scanf("%d",&p->num);//1 2 3 4 0
}
printf("按任意键输出链表!\n");
system("pause");
struct node *r;
r=head;
if(head!=NULL)
do
{
  printf("%d\n",r->num);
  r=r->next;
}
while(r!=NULL);
return 0;
}

                                         
===========深入<----------------->浅出============
2011-06-16 22:06
voidx
Rank: 12Rank: 12Rank: 12
来 自:邯郸
等 级:火箭侠
帖 子:1250
专家分:3538
注 册:2011-4-7
收藏
得分:0 
程序代码:
while(node1.num!=0)
{
  n++;
  if(n==1)
  {
   head=p;
   p->next=NULL;
  }
  else
  {
   q->next=p;

  }
  q=p;
  p=(struct node *)malloc(sizeof(struct node));
  scanf("%d",&node1.num);
}


这段代码楼主只是读取了若干整数,每读一个,就创建一个新的结点并把这个节点添加到链表尾部。可是这个新创建的结点跟楼主读取的整数没有任何关系

[ 本帖最后由 voidx 于 2011-6-16 23:10 编辑 ]
2011-06-16 22:09
快速回复:这个链表输出时为啥又是内存错误,到底是哪出了问题啊?求解。。。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.032856 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved