陈凯彬表示看不懂
这是最简单的了
如有帮助,望采纳
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct student
{
int number;
char name[20];
char banji[20];
char course[20];
int pscore;
int kscore;
int sumsore;
struct student *next;
} ;
struct student *create() //先构造一个结构体
{
struct student *head;
struct student *p1;
p1=(struct student*)malloc(sizeof(struct student)); //申请一个空间
head=p1;
printf("\n学生信息\n"); //输入学生的信息
printf("学号:");
scanf("%d",&p1->number);
printf("姓名:");
scanf("%s",p1->name);
printf("班级:");
scanf("%s",p1->banji);
printf("课程名:");
scanf("%s",p1->course);
printf("平时成绩:");
scanf("%d",&p1->pscore);
printf("考试成绩:");
scanf("%d",&p1->kscore);
printf("总评成绩:");
scanf("%d",&p1->sumsore);
return head;
}
struct student *input(int n) //输入学生信息
{
int i;
char y ;
struct student *head,*pt,*p;
head=pt;
p=(struct student*)malloc(sizeof(struct student)); //申请一个空间
if(i!=1) //判断是不是第一空间
{
for(i=1;i<n;i++)
{
pt=pt->next;
}
pt->next=create();
}
else
{
pt=create();
}
pt=pt->next;
pt->next=p;
pt=pt->next;
pt->next=NULL;
return head;
}
void amend(struct student *head) //修改学生信息
{
int m,k,fale=0;
char z;
struct student *p;
do
{
p=head;
printf("请输入要修改的学生的学号:");
scanf("%d",&m);
do
{
if(p->number==m) //寻找该学号的学生
{
printf("学号:%d\n姓名:%s\n班级:%s\n课程名:%s\n平时成绩:%d\n考试成绩:%d\n总评成绩:%d\n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
printf("\n1.学号\n2.姓名\n3.班级\n4.课程名\n5.平时成绩\n6.考试成绩\n7.总评成绩\n0.不修改");
printf("\n请输入要修改:");
scanf("%d",&k);
printf("修改为:");
switch(k) //对学生学号进行修改
{
case 1:scanf("%d",&p->number);break;
case 2:scanf("%s",p->name);break;
case 3:scanf("%s",p->banji);break;
case 4:scanf("%s",p->course);break;
case 5:scanf("%d",&p->pscore);break;
case 6:scanf("%d",&p->kscore);break;
case 7:scanf("%d",&p->sumsore);break;
case 0:break;
};
fale=1;
break;
}
p=p->next;
}while(p->next!=NULL);
if(fale==0) printf("没有查找到这个人。\n");
printf("是否继续修改(Y/N):"); //是否还进行修改的判断
getchar();
scanf ("%c",&z);
}while(z!='n'&&z!='N');
}
void camcel(struct student *head) // 删除学生信息
{
int i=1,m,k,fale=0;
char z;
struct student *p,*pt;
do
{
p=head;
pt=head;
p=p->next;
printf("请输入要删除的学生的学号:");
scanf("%d",&m);
do
{
if(p->number==m) //寻找该学生
{
printf("学号:%d\n姓名:%s\n班级:%s\n课程名:%s\n平时成绩:%d\n考试成绩:%d\n总评成绩:%d\n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
printf("\n是否要删除(Y/N):");
getchar();
scanf("%c",&k);
if(k=='y'||k=='Y') //对学生删除的操作
{
if(i==1) //先判断是否是第一个学生
{
head->next=p->next;
}
else
{
do
{
pt=pt->next;
}while(pt->next!=p);
pt->next=p->next;
free(p);
}
}
fale=1;
break;
}
i++;
p=p->next;
}while(p->next!=NULL);
if(fale==0) printf("没有查找到这个人。\n");
printf("是否继续修改(Y/N):");
getchar();
scanf ("%c",&z);
}while(z!='n'&&z!='N');
}
void xingmingchaxun(struct student *head) //按姓名查询
{
struct student *p;
char a[20],c;
int fale=0;
do
{
p=head;
printf("输入要查找的姓名:");
scanf("%s",a);
do
{
if(strcmp(p->name,a)==0)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该学生\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void kechengchaxun(struct student *head)// 按课程名称查询
{
struct student *p;
char a[20],c;
int fale=0;
do
{
p=head;
printf("\n输入要查找的课程:");
scanf("%s",a);
do
{
if(strcmp(p->course,a)==0)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该课程\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void xuehaochaxun(struct student *head) // 按学号查询
{
struct student *p;
char c;
int a,fale=0;
do
{
p=head;
printf("\n输入要查找的学号:");
scanf("%d",&a);
do
{
if(p->number==a)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n ",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该学号的学生\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void banjichaxun(struct student *head) //按班级查询
{
struct student *p;
char a[20],c;
int fale=0;
do
{
p=head;
printf("\n输入要查找的班级:");
scanf("%s",a);
do
{
if(strcmp(p->banji,a)==0)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d ",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该班级\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void youxiulv(struct student *head) //查询班级优秀率
{
struct student *p;
char a[20],c;
float n=0,m=-2;
do
{
p=head;
printf("\n输入要查找的优秀率的科目:");
scanf("%s",a);
do
{
if(strcmp(p->course,a)==0)
{
if(p->sumsore>=80)
n++;
}
m++;
p=p->next;
}while(p!=NULL);
printf("该目的优秀率为:%0.2f",n/m) ;
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void zongfengpaixu(struct student *head,int n) //按总分高低排序
{
char c;
int i,j;
struct student *p,temp;
struct student a[n];
p=head;
p=p->next;
for(i=0;i<=n-1;i++)
{
a[i].number=p->number;
strcpy(a[i].name,p->name);
strcpy(a[i].banji,p->banji);
strcpy(a[i].course,p->course);
a[i].pscore=p->pscore;
a[i].kscore=p->kscore;
a[i].sumsore=p->sumsore;
p=p->next;
}
for(i=0;i<=n-1;i++) //冒泡法来排列顺序
{
for(j=0;j<=n-2;j++)
{
if(a[j].sumsore<a[j+1].sumsore)
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
printf("Nes:\n");
do
{
for(i=0;i<n;i++)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",a[i].number,a[i].name,a[i].banji,a[i].course,a[i].pscore,a[i].kscore,a[i].sumsore);
}
printf("\n\n是否退出(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='y'&&c!='Y');
}
void dankechengjipaiming(struct student *head,int n) //单科成绩排名
{
char c,b[20];
int i,j,m;
struct student *p,temp;
struct student a[n];
do
{
m=0;
p=head;
p=p->next;
printf("输入要查找的科目:");
scanf("%s",b);
for(i=0;i<=n-1;i++)
{
if(strcmp(p->course,b)==0)
{
a[m].number=p->number;
strcpy(a[m].name,p->name);
strcpy(a[m].banji,p->banji);
strcpy(a[m].course,p->course);
a[m].pscore=p->pscore;
a[m].kscore=p->kscore;
a[m].sumsore=p->sumsore;
m++;
}
p=p->next;
}
for(i=0;i<=m-1;i++) //冒泡法来排列顺序
{
for(j=0;j<=m-2;j++)
{
if(a[j].sumsore<a[j+1].sumsore)
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
printf("Nes:\n");
for(i=0;i<m;i++)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",a[i].number,a[i].name,a[i].banji,a[i].course,a[i].pscore,a[i].kscore,a[i].sumsore);
}
printf("\n\n是否退出(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='y'&&c!='Y');
}
void pingshifengpaiming(struct student *head,int n)
{
char c;
int i,j;
struct student *p,temp;
struct student a[n];
p=head;
p=p->next;
for(i=0;i<=n-1;i++)
{
a[i].number=p->number;
strcpy(a[i].name,p->name);
strcpy(a[i].banji,p->banji);
strcpy(a[i].course,p->course);
a[i].pscore=p->pscore;
a[i].kscore=p->kscore;
a[i].sumsore=p->sumsore;
p=p->next;
}
for(i=0;i<=n-1;i++) //冒泡法来排列顺序
{
for(j=0;j<=n-2;j++)
{
if(a[j].pscore<a[j+1].pscore)
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
printf("Nes:\n");
do
{
for(i=0;i<n;i++)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",a[i].number,a[i].name,a[i].banji,a[i].course,a[i].pscore,a[i].kscore,a[i].sumsore);
}
printf("\n\n是否退出(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='y'&&c!='Y');
}
void kaoshifengpaiming(struct student *head,int n)
{
char c;
int i,j;
struct student *p,temp;
struct student a[n];
p=head;
p=p->next;
for(i=0;i<=n-1;i++)
{
a[i].number=p->number;
strcpy(a[i].name,p->name);
strcpy(a[i].banji,p->banji);
strcpy(a[i].course,p->course);
a[i].pscore=p->pscore;
a[i].kscore=p->kscore;
a[i].sumsore=p->sumsore;
p=p->next;
}
for(i=0;i<=n-1;i++) //冒泡法来排列顺序
{
for(j=0;j<=n-2;j++)
{
if(a[j].kscore<a[j+1].kscore)
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
printf("Nes:\n");
do
{
for(i=0;i<n;i++)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",a[i].number,a[i].name,a[i].banji,a[i].course,a[i].pscore,a[i].kscore,a[i].sumsore);
}
printf("\n\n是否退出(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='y'&&c!='Y');
}
void pingshichengjichaxun(struct student *head,int n)
{
struct student *p;
char c;
int a,fale=0;
do
{
p=head;
printf("\n输入要查找的平时成绩:");
scanf("%d",a);
do
{
if(a==p->pscore)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该成绩\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
void kaoshichengjichaxun(struct student *head,int n)
{
struct student *p;
char c;
int a,fale=0;
do
{
p=head;
printf("\n输入要查找的考试成绩:");
scanf("%d",a);
do
{
if(a==p->kscore)
{
printf("学号:%d 姓名:%s 班级:%s 课程名:%s 平时成绩:%d 考试成绩:%d 总评成绩:%d \n",p->number,p->name,p->banji,p->course,p->pscore,p->kscore,p->sumsore);
fale=1;
c=1;
}
p=p->next;
}while(p!=NULL);
if(fale==0) printf("\n没有查找到该成绩\n");
printf("\n\n是否继续查找(Y/N):");
getchar();
scanf ("%c",&c);
}while(c!='n'&&c!='N');
}
int jisuan(char a[])
{
int i,sum=0;
for(i=0;a[i]!='\0';i++)
{
if(i==0)
{
sum=a[i]-'0';
}
else
{
sum=sum*10+(a[i]-'0');
}
}
return sum;
}
int main()
{
int n=0,ch=0,th=0;
int *q;
q=&n;
struct student *intput_shuji(int *m);
struct student *create() ;
struct student *input(int n);
void amend(struct student *head) ;
void camcel(struct student *head);
void xingmingchaxun(struct student *head);
void kechengchaxun(struct student *head);
void xuehaochaxun(struct student *head);
void banjichaxun(struct student *head);
void youxiulv(struct student *head);
void zongfengpaixu(struct student *head,int n);
void dankechengjipaiming(struct student *head,int n);
void pingshifengpaiming(struct student *head,int n);
void kaoshifengpaiming(struct student *head,int n);
void pingshichengjichaxun(struct student *head,int n);
void kaoshichengjichaxun(struct student *head,int n);
struct student *head;
do
{
printf("学生成绩管理系统\n\n");
printf("1.学生数据输入\n2.学生数据修改\n3.学生数据查找\n4.学生排名\n5.退出系统") ;
printf("\n----------------------------------------\n") ;
printf("\n要进行的步骤");
scanf("%d",&ch) ;
system("cls");
switch(ch)
{
case 1:{
n++;
head=input(n);
break;
}
case 2:{
do
{
printf("\n1.修改学生信息\n2.删除学生信息\n3.返回上一层\n");
printf("\n要进行的步骤:");
scanf("%d",&th);
switch(th)
{
case 1: amend(head);;break;
case 2:{
camcel(head);
n--;
break;
}
}
system("cls");
}while(th!=3);
break;
}
case 3:{
do
{
printf("\n1.按姓名查询\n2.按班级查询\n3.按学号查询\n4.按课程名称查询\n5.按平时成绩查询\n6.按考试成绩查询\n7.按总成绩查询\n8.返回上一层\n");
printf("\n要进行的步骤:");
scanf("%d",&th);
switch(th)
{
case 1:xingmingchaxun(head);break;
case 2:banjichaxun(head); break;
case 3:xuehaochaxun(head);break;
case 4:kechengchaxun(head);break;
case 5:pingshichengjichaxun(head,n);break;
case 6:kaoshichengjichaxun(head,n);break;
case 7:zongfengpaixu(head,n);break;
}
system("cls");
}while(th!=8);
break;
}
case 4:{
do
{
printf("\n1.按总分高低排序\n2.单科成绩排名\n3.平时分排名\n4.考试分排名\n5.查询班级优秀率\n6.返回上一层\n");
printf("\n要进行的步骤:");
scanf("%d",&th);
switch(th)
{
case 1:zongfengpaixu(head,n);break;
case 2: dankechengjipaiming(head,n);break;
case 3:pingshifengpaiming(head,n);break;
case 4:kaoshifengpaiming(head,n);break;
case 5: youxiulv(head); break;
}
system("cls");
}while(th!=6);
}
break;
}
system("cls");
}while(ch!=5) ;
return 0;
}
#include <stdio.h>
#include <windows.h>
#include <stdlib.h>
#define LEN sizeof(struct Student)
struct Student{
char number[20]; //学号
char name[10]; //姓名
char sex[4]; //性别
int Chinese; //语文成绩
int Math; //数学成绩
int English; //英语成绩
struct Student* next; //指向下一个数据的指针
};
struct Student* head = NULL;
struct Student* end = NULL;
void Menu(){
void Menu();
void Add();
void View();
void Delete();
void Repair();
void ViewAll();
system("cls");
printf("1、学生信息录入\n");
printf("2、学生单个成绩查询\n");
printf("3、查询全部学生成绩\n");
printf("4、修改学生信息\n");
printf("5、删除学生信息\n");
printf("6、退出系统\n");
int choice;
printf("请选择要使用的功能:\n");
loop:
scanf("%d",&choice);
switch (choice) {
case 1:
Add();
Menu();
case 2:
View();
Menu();
case 3:
ViewAll();
Menu();
case 4:
Repair();
Menu();
case 5:
Delete();
Menu();
case 6:
exit(0);
default:
printf("输入有误,请重新选择:");
goto loop;
}
}
void Add(){
system("cls");
int count;
printf("请输入要录入信息的个数:");
scanf("%d",&count);
struct Student *s1,*s2,*temp;
s1=s2=(struct Student*)malloc(LEN);
if(head==NULL){
head = s1;
}else{
end->next = s1 ;
}
int i = 1;
while(count>0){
printf("请输入第%d位学生信息:\n",i++);
printf("学号:\n");
scanf("%s",&s1->number);
printf("姓名:\n");
scanf("%s",&s1->name);
printf("性别:\n");
scanf("%s",&s1->sex);
printf("语文成绩:\n");
scanf("%d",&s1->Chinese);
printf("数学成绩:\n");
scanf("%d",&s1->Math);
printf("英语成绩:\n");
scanf("%d",&s1->English);
count--;
s2->next=s1;
s2=s1;
s1=(struct Student*)malloc(LEN);
printf("添加成功!\n");
system("pause");
system("cls");
}
s2->next= NULL;
end = s2;
printf("全部添加成功!\n");
system("pause");
}
void View(){
system("cls");
struct Student *VS;
printf("输入要查询信息的学生学号:\n");
char num[10];
int flag=1;
scanf("%s",&num);
for(VS=head;VS!=NULL;){
if(strcmp(VS->number,num)==0){
printf("成功找到!\n");
printf("学号:%s\t姓名:%s\t性别:%s\n",VS->number,VS->name,VS->sex);
printf("语文:%d\t数学:%d\t英语:%d",VS->Chinese,VS->Math,VS->English);
flag=0;
break;
}
VS=VS->next;
}
if(flag){
printf("不好意思,未找到!\n");
}
system("pause");
}
void ViewAll(){
system("cls");
struct Student *VA;
if(head!=NULL){
printf("所有学生成绩如下:\n");
for(VA=head;VA!=NULL;){
printf("学号:%s\t姓名:%s\t性别:%s\n",VA->number,VA->name,VA->sex);
printf("语文:%d\t数学:%d\t英语:%d\n",VA->Chinese,VA->Math,VA->English);
VA=VA->next;
}
}else{
printf("该系统中还未录入信息");
}
system("pause");
}
void Repair(){
system("cls");
struct Student *RS;
char num[10];
int flag = 1;
printf("输入要修改成绩学生的学号:\n");
scanf("%s",num);
for(RS=head;RS!=NULL;){
if(strcmp(RS->number,num)==0){
printf("成功找到该学生");
printf("学号:%s\t姓名:%s\t性别:%s\n",RS->number,RS->name,RS->sex);
printf("语文:%d\t数学:%d\t英语:%d\n",RS->Chinese,RS->Math,RS->English);
flag = 0;
printf("学号:\n");
scanf("%s",&RS->number);
printf("姓名:\n");
scanf("%s",&RS->name);
printf("性别:\n");
scanf("%s",&RS->sex);
printf("语文成绩:\n");
scanf("%d",&RS->Chinese);
printf("数学成绩:\n");
scanf("%d",&RS->Math);
printf("英语成绩:\n");
scanf("%d",&RS->English);
printf("修改成功");
system("pause");
}
RS=RS->next;
}
if(flag){
printf("输入信息有误,未查询到");
system("pause");
}
}
void Delete(){
system("cls");
int flag =1;
while(flag){
printf("请输入要删除的学生学号:");
char num[10];
scanf("%s",&num);
struct Student * DS,*temp;
for(DS=head;DS!=NULL;){
if(strcmp(DS->number,num)==0){
if(DS==head){
head = DS->next;
flag = 0;
printf("删除成功!\n");
system("pause");
}else{
flag = 0;
printf("删除成功!\n");
temp->next= DS->next;
free(DS);
system("pause");
}
}
temp = DS;
DS=DS->next;
}
if(flag){
printf("未找到该学生学号!\n");
system("pause");
}
}
}
int main(){
void Menu();
void Add();
void View();
void Delete();
void Repair();
void ViewAll();
Menu();
}
陈凯彬表示看不懂