#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<windows.h>
#include<conio.h>
typedef struct student
{
char id[100];
char name[100];
char room[100];
int math;
int english;
int computer;
int average;
struct student *next;
}STU;
//把数据格式化存入文件
void geshi_file(STU **head)
{
FILE * fp = fopen("C:\\Users\\郝翊博\\Desktop\\ijk.txt","w+");
STU * p_mov = *head;
while(p_mov!=NULL){
fprintf(fp,"学号:%s 名字:%s 班级:%s 数学成绩:%d 英语成绩:%d 计算机成绩:%d 平均成绩:%d\n",p_mov->id, p_mov->name, p_mov->room, p_mov->math,
p_mov->english, p_mov->computer, p_mov->average);
p_mov = p_mov->next;
}
fclose(fp);
}
void link_creat(STU **head, STU *p_new)
{
STU *p_mov=*head;
if(*head==NULL){
*head=p_new;
p_new->next=NULL;
}else{
while(p_mov->next!=NULL){
p_mov=p_mov->next;
}
p_mov->next=p_new;
p_new->next=NULL;
}
}
void space(STU **head, STU *p_new, int n)
{
for(int i=0;i<n;i++){
p_new=(STU*)malloc(sizeof(STU));
printf("请输入学号、姓名、班级、数学成绩、英语成绩、计算机成绩:\n");
scanf("%s %s %s %d%d%d",p_new->id, p_new->name, p_new->room, &p_new->math,
&p_new->english, &p_new->computer);
p_new->average=(p_new->math+p_new->english+p_new->computer)/3;
link_creat(&*head,p_new);
}
}
void link_print(STU *head)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
p_move=p_move->next;
}
if(m)
printf("没有录入学生信息\n");
system("pause");
}
void seek_id(STU *head, char *id)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(strcmp(p_move->id,id)==0){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void BubbleSort(STU **L)
{
int i ,count = 0, num;//count记录链表结点的个数,num进行内层循环,
STU *p, *q, *tail, *m=*L,*o1=*L;//创建三个指针,进行冒泡排序
p = *L;
while(p->next != NULL)//计算出结点的个数
{
count++;//注释①
p = p->next;
}
for(i = 0; i < count - 1; i++)//外层循环,跟数组冒泡排序一样
{
num = count - i - 1;//记录内层循环需要的次数,跟数组冒泡排序一样,
q = m->next;//令q指向第一个结点
p = q->next;//令p指向后一个结点
tail = *L;//让tail始终指向q前一个结点,方便交换,也方便与进行下一步操作
while(num--)//内层循环 次数跟数组冒泡排序一样
{
if(q->english < p->english)//如果该结点的值大于后一个结点,则交换
{
q->next = p->next;
p->next = q;
tail->next = p;
}
tail = tail->next;//注释②
q = tail->next;//注释②
p = q->next;//注释②
}
}
while(o1->next!=NULL){
if(o1->english<o1->next->english){
STU *tem;
strcpy(tem->id,o1->id);
strcpy(tem->name,o1->name);
strcpy(tem->room,o1->room);
tem->average=o1->average;
tem->computer=o1->computer;
tem->english=o1->english;
tem->math=o1->math;
strcpy(o1->id,o1->next->id);
strcpy(o1->name,o1->next->name);
strcpy(o1->room,o1->next->room);
o1->average=o1->next->average;
o1->computer=o1->next->computer;
o1->english=o1->next->english;
o1->math=o1->next->math;
strcpy(o1->next->id,tem->id);
strcpy(o1->next->name,tem->name);
strcpy(o1->next->room,tem->room);
o1->next->average=tem->average;
o1->next->computer=tem->computer;
o1->next->english=tem->english;
o1->next->math=tem->math;
}
o1=o1->next;
}
printf("排序成功.\n");
system("pause");
}
void seek_name(STU *head, char *name)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(strcmp(p_move->name,name)==0){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void seek_room(STU *head, char *room)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(strcmp(p_move->room,room)==0){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void seek_math(STU *head,int n)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(p_move->math==n){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void seek_english(STU *head,int n)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(p_move->english==n){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void seek_computer(STU *head,int n)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(p_move->computer==n){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void seek_average(STU *head,int n)
{
STU *p_move=head;
int m=1;
while(p_move!=NULL){
if(p_move->average==n){
printf("学号:%s\t名字:%s\t班级:%s\t数学成绩:%d\t英语成绩:%d\t计算机成绩:%d\t平均成绩:%d\n",
p_move->id, p_move->name, p_move->room, p_move->math, p_move->english,
p_move->computer, p_move->average);
m=0;
}
p_move=p_move->next;
}
if(m){
printf("没有找到\n");
}
system("pause");
system("cls");
}
void repalce_id(STU *head, char *id1)
{
STU *p=head;
char id[100], name[100], room[100];
int math,english,computer,average,y=1;
while(p!=NULL){
if(strcmp(p->id,id1)==0){
printf("请输入学号、姓名、班级、数学成绩、英语成绩、计算机成绩:\n");
scanf("%s %s %s %d%d%d",id, name,room, &math,&english, &computer);
average=(math+english+computer)/3;
y=0;
p->math=math;
p->english=english;
p->computer=computer;
p->average=average;
strcpy(p->id,id);
strcpy(p->name,name);
strcpy(p->room,room);
printf("修改成功\n");
break;
}
p=p->next;
}
if(y){
printf("没有找到,修改错误\n");
}
system("pause");
system("cls");
}
void repalce_name(STU *head, char *name1)
{
STU *p=head;
char id[100], name[100], room[100];
int math,english,computer,average,y=1;
while(p!=NULL){
if(strcmp(p->name,name1)==0){
printf("请输入学号、姓名、班级、数学成绩、英语成绩、计算机成绩:\n");
scanf("%s %s %s %d%d%d",id, name,room, &math,&english, &computer);
average=(math+english+computer)/3;
p->math=math;
y=0;
p->english=english;
p->computer=computer;
p->average=average;
strcpy(p->id,id);
strcpy(p->name,name);
strcpy(p->room,room);
printf("修改成功\n");
break;
}
p=p->next;
}
if(y){
printf("没有找到,修改错误\n");
}
system("pause");
system("cls");
}
void welcom1(STU *head)
{
while(1){
printf("1.学号 2.姓名\n");
printf("请输入哪种方式修改:");
int choose2;
scanf("%d", &choose2);
system("cls");
char st[100];
switch (choose2) {
case 1:
printf("请输入修改信息学生的学号:");
scanf("%s",st);
repalce_id(head,st);
break;
case 2:
printf("请输入修改信息学生的姓名:");
scanf("%s",st);
repalce_name(head,st);
break;
default:
printf("无效输入,请按要求!");
break;
}
break;
}
}
void welcom2(STU *head)
{
while(1){
printf("1.学号查找 2.姓名查找\n");
printf("3.班级查找 4.英语成绩查找\n");
printf("5.数学成绩查找 6.计算机成绩查找\n");
printf("7.平均成绩查找 8.返回上一界面\n\n");
printf("请输入要查找方式的序号:");
int choose1, w;
char str[100];
scanf("%d", &choose1);
system("cls");
switch(choose1){
case 1:
printf("请输入要查询的学号:");
scanf("%s", str);
seek_id(head,str);
break;
case 2:
printf("请输入要查询的姓名:");
scanf("%s", str);
seek_id(head,str);
break;
case 3:
printf("请输入要查询的班级:");
scanf("%s", str);
seek_id(head,str);
break;
case 4:
printf("请输入要查询的英语成绩:");
scanf("%d", &w);
seek_english(head,w);
break;
case 5:
printf("请输入要查询的数学成绩:");
scanf("%d", &w);
seek_english(head,w);
break;
case 6:
printf("请输入要查询的计算机成绩:");
scanf("%d", &w);
seek_english(head,w);
break;
case 7:
printf("请输入要查询的平均成绩:");
scanf("%d", &w);
seek_english(head,w);
break;
case 8:
w=-1;
break;
default:
printf("无效输入,请按要求!");
break;
}
if(w==-1)
break;
}
}
void dele_link(STU **head, char *id)
{
STU *m=*head, *p=*head,*q;
int n=1,u=1;
while(m!=NULL){
u++;
if(strcmp(m->id,id)==0)
break;
m=m->next;
n++;
}
if(n==1){
q=*head;
*head=q->next;
free(q);
printf("删除成功\n");
}else if(n==u){
printf("删除的学生信息不存在\n");
}else{
for(int j=1; j<n-1; j++){
p=p->next;
}
q=p->next;
int x=0;
if(q==NULL){
printf("删除的学生信息不存在\n");
x=1;
}
if(x==0){
p->next=p->next->next;
free(q);
printf("删除成功\n");
}
}
system("pause");
}
int main() {
STU *hea;
hea = (STU*)malloc(sizeof(STU));
hea->next = NULL;
char zhanghao1[20], zhanghao2[20];
char yin[20];
char mima1[20], mima2 [20];
for (int i = 0; i != 1;) {
int tui=0;
printf("**************************************************\n");
printf("*******************学生管理系统*******************\n");
printf("**************************************************\n");
printf("请选择\n1.登录\n2.注册\n");
char x[20];
printf("请输入你的选项:");
scanf("%s",x);
if (strcmp(x,"1")==0 && strcmp(zhanghao1, yin) == 0 && strcmp(mima1, yin) == 0) {
printf("请先注册账号\n");
system("pause");
system("cls");
continue;
} else if (strcmp(x,"1")==0&& strcmp(zhanghao1, yin) != 0 && strcmp(mima1, yin) != 0) {
while(1) {
printf("请输入学生信息管理系统的账号:\n");
printf("账号:");
scanf("%s", zhanghao2);
printf("请输入学生信息管理系统的密码:\n");
printf("密码:");
scanf("%s", mima2);
if(strcmp(zhanghao1, zhanghao2) == 0 && strcmp(mima1, mima2) == 0){
printf("输入成功");
break;
}else{
printf("输入错误,请重新输入\n");
}
}
} else if (strcmp(x,"2")==0) {
printf("请输入创建的账号");
scanf("%s", zhanghao1);
printf("请输入创建的密码");
scanf("%s", mima1);
system("pause");
system("cls");
continue;
} else {
printf("请输入1或2\n");
system("pause");
system("cls");
continue;
}
STU *head=NULL, *p_new=NULL;
while(1){
system("CLS");
printf("-----------------学生信息管理系统-----------------\n");
printf("1.录入学生信息 2.遍历学生信息\n");
printf("3.删除学生信息 4.修改学生信息\n");
printf("5.查找学生信息 6.按英语成绩排序\n");
printf("7.退出\n\n");
printf("请输入你要进入选项的标号:");
int choose, t;
scanf("%d",&choose);
system("CLS");
switch (choose) {
case 1:
printf("请输入要录入信息的个数:");
scanf("%d",&t);
space(&head, p_new,t);
geshi_file(&head);
break;
case 2:
link_print(head);
break;
case 3:
printf("请输入要删除学生信息的学号:");
char id1[100];
scanf("%s", id1);
dele_link(&head,id1);
break;
case 4:
welcom1(head);
geshi_file(&head);
break;
case 5:
welcom2(head);
break;
case 6:
BubbleSort(&head);
geshi_file(&head);
break;
case 7:
t=-1;
tui=1;
break;
default:
printf("无效输入,请按要求!");
break;
}
if(t==-1)
break;
}
if (tui == 1)
break;
}
return 0;
}
自己应该可以理解,别人就作罢吧,谢谢理解!!!