哈哈,去年我同学让我替他编写过 #include <malloc.h> #include <stdio.h> #include <stdlib.h> #define LEN sizeof(struct scorenode) #define DEBUG #include <string.h> struct scorenode {int number;/*学号*/ char name[10];/*姓名*/ float yuwen;/*语文成绩*/ float yingyu;/*英语成绩*/ float shuxue;/*数学成绩 */ struct scorenode *next; }; typedef struct scorenode score; int n,k;/*n,k为全局变量,本程序中的函数均可以使用它*/ /*==============================================================================================*/ score *creat2311(void) /*函数creat2311,功能:创建链表,此函数带回一个指向链表头的指针*/ { score*head; score *p1,*p2,*p3,*max; int i,j; float fen; char t[10]; n=0; p1=p2=p3=(score *)malloc(LEN);head=p3; /*开辟一个新单元*/ printf("请输入学生资料,输0退出! "); repeat1: printf("请输入学生学号(学号应大于0):");/*输入学号,学号应大于0*/ scanf("%d",&p1->number); while(p1->number<0) {getchar(); printf("输入错误,请重新输入学生学号:"); scanf("%d",&p1->number);} /*输入学号为字符或小于0时,程序报错,提示重新输入学号*/ if(p1->number==0) goto end;/*当输入的学号为0时,转到末尾,结束创建链表*/ else { p3=head; if(n>0) {for(i=0;i<n;i++) {if(p1->number!=p3->number) p3=p3->next; else {printf("学号重复,请重输! "); goto repeat1; /*当输入的学号已经存在,程序报错,返回前面重新输入*/ } } } } printf("请输入学生姓名:"); scanf("%s",&p1->name);/*输入学生姓名*/ printf("请输入语文成绩(0~100):");/*输入语文成绩,成绩应在0-100*/ scanf("%f",&p1->yuwen); while(p1->yuwen<0||p1->yuwen>100) {getchar(); printf("输入错误,请重新输入语文成绩");/*输入错误,重新输入语文成绩直到正确为止*/ scanf("%f",&p1->yuwen);} printf("请输入英语成绩(0~100):");/*输入英语成绩,成绩应在0-100*/ scanf("%f",&p1->yingyu); while(p1->yingyu<0||p1->yingyu>100) {getchar(); printf("输入错误,请重新输入英语成绩");/*输入错误,重新输入英语成绩直到正确为止*/ scanf("%f",&p1->yingyu);} printf("请输入数学成绩(0~100):");/*输入数学成绩,成绩应在0-100*/ scanf("%f",&p1->shuxue); while(p1->shuxue<0||p1->shuxue>100) {getchar(); printf("输入错误,请重新输入数学成绩"); scanf("%f",&p1->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/ head=NULL; while(p1->number!=0) { n=n+1; if(n==1) head=p1; else
p2->next=p1; p2=p1; p1=(score *)malloc(LEN); printf("请输入学生资料,输0退出! "); repeat2:printf("请输入学生学号(学号应大于0):"); scanf("%d",&p1->number);/*输入学号,学号应大于0*/ while(p1->number<0) {getchar(); printf("输入错误,请重新输入学生学号:"); scanf("%d",&p1->number);} /*输入学号为字符或小于0时,程序报错,提示重新输入学号*/ if(p1->number==0) goto end;/*当输入的学号为0时,转到末尾,结束创建链表*/ else { p3=head; if(n>0) {for(i=0;i<n;i++) {if(p1->number!=p3->number) p3=p3->next; else {printf("学号重复,请重输! "); goto repeat2; /*当输入的学号已经存在,程序报错,返回前面重新输入*/ } } }
} printf("请输入学生姓名:"); scanf("%s",&p1->name);/*输入学生姓名*/ printf("请输入语文成绩(0~100):"); scanf("%f",&p1->yuwen);/*输入语文成绩,成绩应在0-100*/ while(p1->yuwen<0||p1->yuwen>100) {getchar(); printf("输入错误,请重新输入语文成绩"); scanf("%f",&p1->yuwen);}/*输入错误,重新输入语文成绩直到正确为止*/ printf("请输入英语成绩(0~100):"); scanf("%f",&p1->yingyu);/*输入英语成绩,成绩应在0-100*/ while(p1->yingyu<0||p1->yingyu>100) {getchar(); printf("输入错误,请重新输入英语成绩"); scanf("%f",&p1->yingyu);}/*输入错误,重新输入英语成绩直到正确为止*/ printf("请输入数学成绩(0~100):"); scanf("%f",&p1->shuxue);/*输入数学成绩,成绩应在0-100*/ while(p1->shuxue<0||p1->shuxue>100) {getchar(); printf("输入错误,请重新输入数学成绩"); scanf("%f",&p1->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/ }
end: p1=head; p3=p1; for(i=1;i<n;i++) { for(j=i+1;j<=n;j++) { max=p1; p1=p1->next; if(max->number>p1->number) { k=max->number; max->number=p1->number; p1->number=k; /*交换前后结点中的学号值,使得学号大者移到后面的结点中*/ strcpy(t,max->name); strcpy(max->name,p1->name); strcpy(p1->name,t); /*交换前后结点中的姓名,使之与学号相匹配*/ fen=max->yuwen; max->yuwen=p1->yuwen; p1->yuwen=fen; /*交换前后结点中的语文成绩,使之与学号相匹配*/ fen=max->yingyu; max->yingyu=p1->yingyu; p1->yingyu=fen; /*交换前后结点中的英语成绩,使之与学号相匹配*/ fen=max->shuxue; max->shuxue=p1->shuxue; p1->shuxue=fen; /*交换前后结点中的数学成绩,使之与学号相匹配*/ }
} max=head;p1=head;/*重新使max,p指向链表头*/ } p2->next=NULL;/*链表结尾*/ printf("输入的学生数为:%d个! ",n); return(head);
} /*==============================================================================================*/ /*==============================================================================================*/ score *load2311(score *head) /*函数load2311,功能:从文件读入学生记录*/ { score *p1,*p2; int m=0; char filepn[10]; FILE *fp; printf("请输入文件路径及文件名:"); scanf("%s",filepn);/*输入文件路径及名称*/ if((fp=fopen(filepn,"r+"))==NULL) { printf("不能打开文件! "); return 0; } fscanf(fp," 考试成绩管理系统 "); fscanf(fp,"作者:周纯钢 班级: 信息023 学号:11 "); fscanf(fp,"----------------------------------------- "); fscanf(fp,"|学号 |姓名 |语文 |英语 |数学 | "); fscanf(fp,"----------------------------------------- ");/*读入表格域*/ printf(" 考试成绩管理系统 "); printf(" 作者:周纯钢 班级: 信息023 学号:11 "); printf("----------------------------------------- "); printf("|学号 |姓名 |语文 |英语 |数学 | "); printf("----------------------------------------- ");/*打印表格域*/ m=m+1; if(m==1) { p1=(score *)malloc(LEN); /*开辟一个新单元*/ fscanf(fp,"%d%s%f%f%f",&p1->number,p1->name,&p1->yuwen,&p1->yingyu,&p1->shuxue); printf("|%d |%s |%.1f |%.1f |%.1f | ",p1->number,p1->name,p1->yuwen,p1->yingyu,p1->shuxue); /*文件读入与显示*/ head=NULL; do { n=n+1; if(n==1) head=p1; else p2->next=p1; p2=p1; p1=(score *)malloc(LEN); /*开辟一个新单元*/ fscanf(fp,"%d%s%f%f%f ",&p1->number,p1->name,&p1->yuwen,&p1->yingyu,&p1->shuxue); printf("|%d |%s |%.1f |%.1f |%.1f | ",p1->number,p1->name,p1->yuwen,p1->yingyu,p1->shuxue); /*文件读入与显示*/ }while(!feof(fp)); p2->next=p1; p1->next=NULL; n=n+1; }printf("----------------------------------------- ");/*表格下线*/ fclose(fp);/*结束读入,关闭文件*/ return (head); }
/*==============================================================================================*/ /*==============================================================================================*/ score *add2311(score *head,score *stu) /*函数add2311,功能:追加学生资料,并且将所有学生资料按学号排序*/ { score *p0,*p1,*p2,*p3,*max; int i,j; float fen; char t[10];
p3=stu=(score *)malloc(LEN);/*开辟一个新单元*/ printf(" 输入要增加的学生的资料!"); repeat4: printf("请输入学生学号(学号应大于0):"); scanf("%d",&stu->number); /*输入学号,学号应大于0*/ while(stu->number<0) {getchar(); printf("输入错误,请重新输入学生学号:"); scanf("%d",&stu->number);}/*输入错误,重新输入学号*/ /******************************************************/ if(stu->number==0) goto end2;/*当输入的学号为0时,转到末尾,结束追加*/ else { p3=head; if(n>0) {for(i=0;i<n;i++) {if(stu->number!=p3->number) p3=p3->next; else {printf("学号重复,请重输! "); goto repeat4; /*当输入的学号已经存在,程序报错,返回前面重新输入*/ } } }
} /******************************************************/ printf("输入学生姓名:"); scanf("%s",stu->name); /*输入学生姓名*/ printf("请输入语文成绩(0~100):"); scanf("%f",&stu->yuwen); /*输入语文成绩,成绩应在0-100*/ while(stu->yuwen<0||stu->yuwen>100) {getchar(); printf("输入错误,请重新输入语文成绩"); scanf("%f",&stu->yuwen);} /*输入错误,重新输入语文成绩直到正确为止*/ printf("请输入英语成绩(0~100):"); scanf("%f",&stu->yingyu);/*输入英语成绩,成绩应在0-100*/ while(stu->yingyu<0||stu->yingyu>100) {getchar(); printf("输入错误,请重新输入英语成绩"); scanf("%f",&stu->yingyu);}/*输入错误,重新输入英语成绩直到正确为止*/ printf("请输入数学成绩(0~100):"); scanf("%f",&stu->shuxue);/*输入数学成绩,成绩应在0-100*/ while(stu->shuxue<0||stu->shuxue>100) {getchar(); printf("输入错误,请重新输入数学成绩"); scanf("%f",&stu->shuxue);}/*输入错误,重新输入数学成绩直到正确为止*/ p1=head; p0=stu; if(head==NULL) {head=p0;p0->next=NULL;}/*当原来链表为空时,从首结点开始存放资料*/ else/*原来链表不为空*/ { if(p1->next==NULL)/*找到原来链表的末尾*/ { p1->next=p0; p0->next=NULL;/*将它与新开单元相连接*/ } else { while(p1->next!=NULL)/*还没找到末尾,继续找*/ { p2=p1;p1=p1->next; } p1->next=p0; p0->next=NULL; }
} n=n+1;
傲游主机商我们可能很多人并不陌生,实际上这个商家早年也就是个人主机商,传说是有几个个人投资创办的,不过能坚持到现在也算不错,毕竟有早年的用户积累正常情况上还是能延续的。如果是新服务商这几年确实不是特别容易,问到几个老牌的个人服务商很多都是早年的用户积累客户群。傲游主机目前有提供XEN和KVM架构的云服务器,不少还是亚洲CN2优化节点,目前数据中心包括中国香港、韩国、德国、荷兰和美国等多个地区的CN...
A400互联是一家成立于2020年的商家,主要推行洛杉矶服务器采用kvm架构,线路优质,延迟低,稳定性高!全场产品对标腾讯云轻量,服务器线路有有美国洛杉矶cn2_gia、香港cn2+cmi,目前推行的vps服务器均为精心挑选的优质线路机房,A400互联推出了夏季优惠洛杉矶5折、香港7折促销活动,质量可靠,价格实惠!二:优惠码洛杉矶五折优惠码:20210620香港cn2七折优惠码:0710三、优惠方...
Cloudxtiny是一家来自英国的主机商,提供VPS和独立服务器租用,在英国肯特自营数据中心,自己的硬件和网络(AS207059)。商家VPS主机基于KVM架构,开设在英国肯特机房,为了庆祝2021年欧洲杯决赛英格兰对意大利,商家为全场VPS主机提供50%的折扣直到7月31日,优惠后最低套餐每月1.5英镑起。我们对这场比赛有点偏见,但希望这是一场史诗般的决赛!下面列出几款主机套餐配置信息。CPU...