急请高手帮忙修改下我的数据结构程序
下面是我自己编的一个小程序,编译组建时都没有错误,就是运行是出错,请哪位高手帮忙看下,小弟在此先谢了!
#include <stdio.h>
#include <string.h>
#include<stdlib.h>
#define LEN sizeof(struct student)
typedef struct student
{
char num[8];/*学号*/
char name[9];/*姓名*/
char gender[3];/*性别*/
int score;/*成绩*/
struct student *next;
}sequenlist;
int menu_select()
{
int sn;
printf("\n 学生信息管理系统\n");
printf("=========================================\n");
printf(" 1.学生信息线性表的建立\n");
printf(" 2.插 入 学 生 信 息\n");
printf(" 3.查 询 学 生 信 息\n");
printf(" 4.删 除 学 生 信 息\n");
printf(" 5.输 出 所有学生信息\n");
printf(" 0.退 出 管 理 系 统\n");
printf("==========================================\n");
printf("请选择0-5:\n");
for(;;)
{
scanf("%d",&sn);
if (sn<0 || sn>5)
printf("\n\t输入错误,重选0-5\n");
else
break;
}
return sn;
}
void createList(sequenlist*p1)
{
int n,i,j=0;sequenlist *p2;
printf("有几位学生?请输入:\n");
fflush(stdin);
scanf("%d",&n);
printf("以下请输入这%d位学生的信息:\n",n);
for(i=0;i<n;i++)
{
p2=(sequenlist *)malloc(LEN);
printf("第%d位学生信息为:\n",i);
scanf("%s%s%s%d",p2->num,p2->name,p2->gender,&p2->score);
p1->next=p2;
p1=p2;
}
p1->next=NULL;
}
void printList(sequenlist *head)
{
sequenlist *p;
printf("\n学号(8) 姓名(8) 性别 成绩\n");
printf("-------------------------------------------\n");
p=head;p=p->next;
if(head!=NULL)
do
{ printf("%s,%s,%s,%f\n",p->num,p->name,p->gender,p->score);
printf("------------------------------------------------------------------\n");
p=p->next;
}while(p);
}
void insert(sequenlist *L,int i)
{ sequenlist * p=L->next,*s;int j=1;
while(p&&j<i-1){p=p->next; ++j;}
s=(sequenlist *)malloc(LEN);
scanf("%s%s%s%d",s->num,s->name,s->gender,&s->score);
s->next=p->next;
p->next=s;}
sequenlist * findList(sequenlist *L)
{sequenlist *P=L->next;
char num[8];
char name[9];
int xz;
printf("===========================\n");
printf("1、按学号查询\n");
printf("2、按姓名查询\n");
printf("===========================\n");
printf(" 请选择: ");
fflush(stdin);
scanf("%d",&xz);
if (xz==1)
{
printf("请输入要查找学生的学号:");
scanf("%s",num);
while(P->num!=num){P=P->next;};
if(P==NULL){printf("没有要找的学生\n");return(NULL);}
else
return(P);
}
else if (xz==2)
{
printf("请输入要查找学生的姓名:");
scanf("%s",name);
while(P->name!=name){P=P->next;};
if(P==NULL){printf("没有要找的学生\n");return(NULL);}
else return(P);}
}
void delNode(sequenlist *L)
{char num[8];
sequenlist * P1,*p2,*head;
printf("请输入要删除的结点num\n");
scanf("%s",num);
P1=L->next;head=L->next;
while(num!=P1->num&&P1->next!=NULL)
{p2=P1;P1=P1->next;}
if(num==P1->num)
{if(P1==head)head=P1->next;
else p2->next=P1->next;free(P1);printf("信息已删除\n");}
else printf("没有要删除的信息\n");
}
void main()
{
sequenlist *p1,*p;
int i;
while(1) {switch(menu_select())
{
case 1:
printf("**************************************\n");
printf(" 学生信息线性表的建立 \n");
printf("***************************************\n");
p1=(sequenlist *)malloc(LEN);
createList(p1);
break;
case 2:
printf("**************************************\n");
printf("添加学生信息\n");
printf("请输入要插入的位置:\n");
fflush(stdin);
scanf("%d",&i);
insert(p1,i);
break;
case 3:
printf("**************************************\n");
printf("查询学生信息\n");
printf("**************************************\n");
p=findList(p1);
if(p!=NULL)
{
printf("您要查的学生为:\n学号(8) 姓名(8) 性别 成绩\n");
printf("-------------------------------------------\n");
printf("%s,%s,%s,%d\n",p->num,p->name,p->gender,p->score);
printf("------------------------------------------------------------------\n");
}
else
printf("没有您要查询的学生信息!");
break;
case 4:
printf("**************************************\n");
printf("删除学生信息\n");
printf("**************************************\n");
delNode(p1);
break;
case 5:
printf("**************************************\n");
printf("输出所有学生信息\n");
printf("**************************************\n");
printList(p1);
break;
case 0:
printf("再见!\n");
getchar();
return;
}}
}