C语言链表问题,高手进,急啊!!! 重赏!!!

#include<stdio.h>#include<malloc.h>#include<stdlib.h>#defineLENsizeof(structStudent)#... #include<stdio.h>
#include<malloc.h>
#include <stdlib.h>
#define LEN sizeof(struct Student)
#define N 100
struct Student
{
long num;
int score;
char name[20];
struct Student * next;
};
int n;
struct Student * creat(void)
{
struct Student * head;
struct Student * p1, * p2;
n=0;
p1=p2=(struct Student * )malloc(LEN);
printf("请依次录入学生学号,姓名,分数-------------------输入0为输入完毕\n");
scanf("%ld %s %d",&p1->num,p1->name,&p1->score);
head=NULL;
while(p1->num!=0)
{
n=n+1;
if(n==1)head=p1;
else p2->next=p1;
p2=p1;
p1=(struct Student * )malloc(LEN);
scanf("%ld %s %d",&p1->num,p1->name,&p1->score);
}
p2->next=NULL;
return(head);
}
void prin(struct Student *head)
{
struct Student *p;
printf("\n\n现在,您录入的数据是:\n");
p=head;
if(head!=NULL)
do
{
printf("%ld,%s,%d\n",p->num,p->name,p->score);
p=p->next;
} while(p!=NULL);
getchar();
}
void Listlink(struct Student *head)
{
struct Student *p;
int i;
p=head;
int m=0;
printf("\n请你输入你将要查找的该学生的位置i=");
scanf("%d",&i);
while(p->next!=NULL&&m<i-1)
{
p=p->next;
m++;
}
if(!p)
printf("您查找的位置不正确!\n");
else
{
printf("%ld,%s,%d\n",p->num,p->name,p->score);
}
getchar();
}
Student *ListInsert(struct Student *head)
{
int i;
int j=0;
struct Student *p1,*p2;
if((p1=(struct Student*)malloc(sizeof(struct Student)))=NULL)
{
printf("不能分配内存空间\n");
exit(0);
}
printf("\n请你输入你将要插入的位置i=");
scanf("%d",&i);
printf("\n请你输入你要插入的数据(学号,姓名,分数)\n");
scanf("%ld %s %d",&p1->num,p1->name,&p1->score);
p1->next=NULL;
p2=head;
if(i==0)
{
p1->next=p2->next;
p2->next=p1;
}
if(i>N)
{
while(p2->next!=NULL)
p2=p2->next;
p2->next=p1;
p1->next=NULL;
}
if(i<N&&i>0)
{
while(j<i-1)
{
p2=p2->next;
j++;
}
p1->next=p2->next;
p2->next=p1;
}
return(head);
}
void display()
{
getchar();
printf("\n\n1.....插入你所要查找的学生学号......\n");
printf("2.....删除你所要查找的学生学号......\n");
printf("3.....查找你所要查找的学生学号......\n");
printf("4........输出此时学生的学号.........\n");
printf("5.............清除屏幕..............\n");
printf("input 1..5:");
}
void main()
{
struct Student * head;
head=creat();
prin(head);
int choose;
while(choose!=0)
{
display();
scanf("%d",&choose);
switch(choose)
case 1:ListInsert(head);break;
case 2:ListDelete(head);break;
case 3:Listlink(head);break;
case 4:prin(head);break;
case 5:system("cls");break;
default:system("cls");
printf("没有该选项,请您重新选择!");
choose='5';
break;
}
}
}
看一下这段程序,执行,插入操作,为什么一插入数据之后按回车就会自动关闭,我想实现的是在任意一个节点位置,插入一组(学号,姓名,分数)的数据,然后不影响原有链表数据,在第几个节点插入就在第几个节点显示出来!!!急啊,高手帮帮忙,帮忙看看,哪里有毛病或者可以改正一下!
展开
 我来答
xtjmdw
2012-03-18 · TA获得超过278个赞
知道小有建树答主
回答量:394
采纳率:0%
帮助的人:253万
展开全部
p1=(struct Student*)malloc(sizeof(struct Student)))=NULL

==NULL吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Go浪人生
2012-03-18 · TA获得超过2473个赞
知道小有建树答主
回答量:738
采纳率:100%
帮助的人:971万
展开全部
1、ListInsert 这个函数里的if((p1=(struct Student*)malloc(sizeof(struct Student)))=NULL)
应该写成 if((p1=(struct Student*)malloc(sizeof(struct Student)))==NULL) 不然后面的NULL没用,那么如果p1不是NULL,就会执行exit。
2、你用了scanf,会在缓冲区保留一个'\n'符。当循环的第二次调用 scanf时就不会提示你输入了,这时choose的值就为0了,那么就会退出循环。
while(choose!=0)
{
display();
scanf("%d",&choose);
getchar();
这样就不会了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式