文章目录
- 一、子函数
- 1.链表初始化start(),start2()
- 2、创建链表creat(LinkList head)
- 3、查询seek(LinkList head)
- 4、插入insert(LinkList head)
- 5、删除Delete(LinkList head)
- 6、修改change(LinkList head)
- 7、将链表中的信息写入文件write(LinkList head)、write2(LinkList head)
- 8、排序sort(LinkList head)
- 9、计算平均分aver(LinkList head)
- 10、输出output1(LinkList head)、pass(LinkList head,LinkList head2)
- 二、主函数
- 三、关于system函数(此处只说明以上代码涉及的system参数)
一、子函数
在写子函数之前,先定义一个结构体
typedef struct student
{
char num[100];//学号
char name[100]; //姓名
int score;//成绩
struct student *next;//结构体指针
}node,*LinkList;
1.链表初始化start(),start2()
LinkList start()//总数据
{
LinkList head;
head=(node*)malloc(sizeof(node));
head->next=NULL;
return head;
}
LinkList start2()//不及格名单
{
LinkList head2;
head2=(node*)malloc(sizeof(node));
head2->next=NULL;
return head2;
}
2、创建链表creat(LinkList head)
将文件里的信息写入链表,方便操作
void creat(LinkList head)
{
FILE* fp;
LinkList s,r;
fp=fopen("D:\\管理系统\\xinxi.txt","r");
s=head;
while(!feof(fp))
{
r=(node*)malloc(sizeof(node));
fscanf(fp,"%s %s %d\n",r->num,r->name,&r->score);
/*if(fscanf(fp,"%s %s %s %d\n",r->num,r->name,r->maj,&r->score)==EOF)
break;*/
s->next=r;
s=r;
}
s->next=NULL;
fclose(fp);
}
3、查询seek(LinkList head)
void seek(LinkList head)
{
LinkList p;
int f=0;
char a[100];
printf("请输入要查询学生的学号:");
scanf("%s",a);
printf("\n");
p=head->next;
while(p)
{
if(strcmp(p->num,a)==0)
{
f=1;
break;
}
else
p=p->next;
}
if(f==1)
{
printf("学号:%s 姓名:%s 综测:%d\n",p->num,p->name,p->score);
}
else
printf("该学生不存在!\n\n");
printf("\n");
system("pause");
}
4、插入insert(LinkList head)
void insert(LinkList head)
{
LinkList q=head,s;
int j,i;
printf("请输入要插入的位置:");
scanf("%d",&i);
for(j=0;(j<i-1)&&q;j++)
{
q=q->next;
}
if(q)
{
printf("请输入待插入学生的学号姓名及综测:\n");
s=(node*)malloc(sizeof(node));
scanf("%s",s->num);
scanf("%s",s->name);
scanf("%d",&s->score);
s->next=q->next;
q->next=s;
}
printf("\n");
system("pause");
}
5、删除Delete(LinkList head)
void Delete(LinkList head)
{
LinkList q=head,s;
int f=0;
char b[100];
printf("请输入要删除的学生的学号:");
gets(b);
while(q->next)
{
if(strcmp(b,q->next->num)==0)
{
f=1;
break;
}
else
q=q->next;
}
if(f==1)
{
s=(node*)malloc(sizeof(node));
if(q&&q->next)
{
s=q->next;
q->next=s->next;
free(s);
}
}
else
printf("该学生不存在!\n\n");
printf("\n");
system("pause");
}
6、修改change(LinkList head)
void change(LinkList head)
{
LinkList q=head,s;
int f=0;
char b[100];
printf("请输入要修改成绩的学生的学号:");
scanf("%s",b);
printf("\n");
while(q->next)
{
if(strcmp(b,q->next->num)==0)
{
f=1;
break;
}
else
q=q->next;
}
if(f==1)
{
printf("请输入修改后的成绩:");
scanf("%d",&q->next->score);
}
else
printf("该学生不存在!\n\n");
printf("\n");
system("pause");
}
7、将链表中的信息写入文件write(LinkList head)、write2(LinkList head)
void write(LinkList head)//总信息
{
FILE *fp;
LinkList p=head->next;
fp=fopen("D:\\管理系统\\xinxi.txt","w");
while(p)
{
fprintf(fp,"%s %s %d\n",p->num,p->name,p->score);
p=p->next;
}
fclose(fp);
}
void write2(LinkList head)//不及格名单
{
FILE *fp;
LinkList p=head->next;
fp=fopen("D:\\管理系统\\不及格名单.txt","w");
while(p)
{
fprintf(fp,"%s %s %d\n",p->num,p->name,p->score);
p=p->next;
}
fclose(fp);
}
8、排序sort(LinkList head)
void sort(LinkList head)
{
int c[10000],t=0,i,j,k;
LinkList p=head->next;
while(p)
{
c[t++]=p->score;
p=p->next;
}
for(i=0;i<t;i++)
{
for(j=0;j<t-i-1;j++)
{
if(c[j]>c[j+1])
{
k=c[j];
c[j]=c[j+1];
c[j+1]=k;
}
}
}
for(i=0;i<t;i++)
{
p=head->next;
while(p)
{
if(p->score==c[i])
{
printf("学号:%s 姓名:%s 综测:%d\n",p->num,p->name,p->score);
}
p=p->next;
}
}
printf("\n");
system("pause");
}
9、计算平均分aver(LinkList head)
void aver(LinkList head)
{
int c[10000],i;
float sum=0;
int t=0;
LinkList p=head->next;
while(p)
{
c[t++]=p->score;
p=p->next;
}
for(i=0;i<t;i++)
{
sum=sum+c[i];
}
printf("平均分为:%f\n\n",sum/t);
printf("\n");
system("pause");
}
10、输出output1(LinkList head)、pass(LinkList head,LinkList head2)
{
void output1(LinkList head)//输出总信息
{
LinkList p=head->next;
while(p)
{
printf("学号:%s 姓名:%s 综测:%d\n",p->num,p->name,p->score);
p=p->next;
}
printf("\n");
system("pause");
}
void pass(LinkList head,LinkList head2)//输出不及格的信息
{
LinkList p=head->next,r=head2,s;
while(p)
{
if(p->score<60)
{
printf("学号:%s 姓名:%s 综测:%d\n",p->num,p->name,p->score);
s=(node*)malloc(sizeof(node));
strcpy(s->num,p->num);
strcpy(s->name,p->name);
s->score=p->score;
r->next=s;
r=s;
}
p=p->next;
}
r->next=NULL;
printf("\n");
system("pause");
}
二、主函数
int main()
{
printf(" *********************************************************************************\n");
printf(" *********************************************************************************\n");
printf(" ");
printf(" 欢迎进入学生信息管理系统!\n");
printf(" ");
printf(" *********************************************************************************\n");
printf(" *********************************************************************************\n");
printf("\n\n\n");
system("pause");
system("cls");
printf("进入学生端:请输入0\n");
printf("\n");
printf("进入教师端:请输入1\n");
printf("\n");
LinkList head,head2;
head=start();
head2=start2();
creat(head);
int n,m,k,y;
scanf("%d",&n);
switch(n)
{
case 0:seek(head);break;
case 1:
{
while(1)
{
printf("1.输出学生信息\n\n");
printf("2.增加学生信息\n\n");
printf("3.修改学生信息\n\n");
printf("4.查询平均分\n\n");
printf("5.输出不及格的学生的学号姓名以及成绩\n\n");
printf("6.继续操作\n\n") ;
printf("7.退出\n\n");
scanf("%d",&m);
printf("\n");
switch(m)
{
case 1:
{
printf("1.默认输出\n\n");
printf("2.顺序输出\n\n");
scanf("%d",&k);
switch(k)
{
case 1:output1(head);break;
case 2:sort(head);break;
}
break;
}
case 2:
{
insert(head);
write(head);
break;
}
case 3:
{
change(head);
write(head);
break;
}
case 4:aver(head);break;
case 5:
{
pass(head,head2);
printf("\n是否导出不及格学生的名单?\n\n");
printf("1.导出\n\n");
printf("2.不导出\n\n");
scanf("%d",&y);
switch(y)
{
case 2:break;
case 1:write2(head2);break;
}
break;
}
case 6:continue;
case 7:
{
printf("已退出程序!\n");
exit(0);
break;
}
}
}
}
}
//output1(head);
//seek(head);
//insert(head);
//Delete(head);
//change(head);
//sort(head);
//write(head);
//aver(head);
}
三、关于system函数(此处只说明以上代码涉及的system参数)
1、system(“pause”) 屏幕上出现请按任意键继续;
2、system(“cls”) 用于清楚屏幕代码。