189 8069 5689

C语言学生成绩管理系统课程设计-创新互联

学生成绩管理系统是比较适合初学者的。它涵盖了c语言几乎知识。对于学了c语言的人,把这个课程设计搞好(当然自己能设计出来是要有很好的基础)。不管自己能不能够完成,最重要的是能弄懂。参考其他资料,试着自己编写是不错的选择。这个课程设计也是我参照资料,自己编写的。自己适当地增加了一些功能。不过,编的不够那么专业吧。

创新互联建站长期为1000多家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为建华企业提供专业的成都网站建设、成都做网站,建华网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。
#include 
#include 
#include 
#define size 100 
 
 
char* classname[]={"语文","数学","英语"}; 
int N=0,falg=0; //定义全局变量 N代表人数,falg代表信息保存的标识。 
int arrysize=size; //arrysize代表结构体数组的大小。  
struct stu{ 
char num[10]; 
char name[10]; 
float score[3]; 
float sum; 
}; 
typedef struct stu STU; //定义新类型的结构体。 
STU*pro=NULL; // pro保存信息的结构体数组。 
 
 
int chack(int a,int b,int c) //条件判断函数,c代表条件号。 
{ 
if(c==1||c==2) 
{ 
if(pro[a].sum !=pro[b].sum ) 
if(c==1) 
 return pro[a].sum >pro[b].sum ; 
else 
return pro[a].sum 0; 
} 
else printf("没有该条件的选项!\n"); 
return 0; 
} 
 
 
void incharge(int a,int b) //交换函数。 
{ 
 struct stu t; 
 t=pro[a]; 
 pro[a]=pro[b]; 
 pro[b]=t; 
} 
 
 
void het(int m,int n,int c) //快排函数 
{ if(m>n) return; 
int i=m-1; 
for(int j=m;jnum,p->num); 
strcpy(q->name,p->name); 
for(int j=0;j<3;j++) 
q->score[j]=p->score[j]; 
 q->sum=p->sum; 
} 
 
 
void remove() //删除个人信息函数 
{ int b; 
 char tag[10]; 
if(N==0){ 
printf("记录表为空!\n"); 
return; 
} 
b=lookout(); 
if(b) 
{ 
printf("是否要删除(y/n):"); 
 gets(tag); 
if(tag[0]=='y'||tag[0]=='Y') 
{ 
N--; 
for(int j=b;j<=N;j++) 
copyrecored(&pro[j+1],&pro[j]); 
printf("删除成功!\n"); 
falg=0; 
} 
else printf("删除失败!\n"); 
} 
} 
void change() //修改个人信息函数 
{ int m,k,f; 
 if(N==0) 
{printf("记录表为空!\n");return;} 
 k=lookout(); 
 if(k) 
 { 
 printf("1.学号 2.姓名 3科目成绩 4.全部修改 0.退出\n请输入要修改的信息:"); 
scanf("%d",&f); 
switch(f) 
{ 
case 1:printf("请重新输入学号:"); 
 scanf("%s",&pro[k].num );falg=0;break; 
case 2:getchar(); 
 printf("请重新输入姓名:"); 
 scanf("%s",&pro[k].name);falg=0;break; 
case 3:printf("0.语文 1.数学 2.英语\n请选择科目:"); 
 scanf("%d",&m); 
 if(m==0||m==1||m==2) 
{ 
printf("请输入%s成绩:",classname[m]); 
 scanf("%f",&pro[k].score[m]); 
falg=0; 
} 
 else printf("输入无效!\n"); 
 pro[k].sum=pro[k].score[0]+pro[k].score[1]+pro[k].score[2]; 
 break; 
case 4:newsect(k);break; 
default:printf("修改失败!"); break; 
} 
 } 
} 
 
 
void save()  //文件保存函数 
{ 
FILE *fp; 
 char fname[30]; 
if(N==0) 
{ 
printf("没有记录可存!\n");return; 
} 
loop:printf("请输入要存入的文件(直接回车保存在默认文件中):"); 
gets(fname); 
if(strlen(fname)==0) 
 strcpy(fname,"stu_info"); 
 if((fp=fopen(fname,"wb"))==NULL){ 
 printf("不能存入文件!\n");goto loop; 
 } 
 printf(" 文件保存中....\n"); 
 for(int i=1;i<=N;i++) 
 if((fwrite(&pro[i],sizeof(STU),1,fp))==0) 
 {printf("保存失败!\n");break;} 
 fclose(fp); 
 printf("文件已保存!\n"); 
 falg=1; 
} 
 
 
void loadrecords() //读取文件函数 
{ 
FILE *fp; 
void abc(int s); 
char fname[10]; 
int c; 
struct stu records[100]; 
printf("请输入要打开的文件名(直接回车打开默认文件):"); 
gets(fname); 
if(strlen(fname)==0) 
strcpy(fname,"stu_info"); 
if((fp=fopen(fname,"rb"))==NULL) 
{ 
printf("文件打不开!\n");return; 
} 
printf("1.覆盖新建的信息 2.添加到新的信息中 3.查看保存的信息\n请选择:"); 
scanf("%d",&c); 
if(c==3){ 
printf("\n┏┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┓\n"); 
 printf("┃学号 姓名 总成绩 语文 数学 英语 ┃ \n"); 
for(int i=0;fread(&records[i],sizeof(STU),1,fp)!=0;i++) 
{ 
printf("┃%-12s% -11s% -9.1f ",records[i].num ,records[i].name,records[i].sum ); 
for(int j=0;j<3;j++) 
printf(j==2?"%-5.1f":"%-8.1f",records[i].score [j]); 
printf(" ┃\n"); 
} 
printf("\n┗┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┉┛\n"); 
} 
if(c==1){ 
abc(0); 
for( N=1;fread(&pro[N],sizeof(STU),1,fp)!=0;N++); 
N--;    //跳出循环,N实际比得到人数要大一,故要减一。 
falg=0;     
fclose(fp); 
showlist(); 
} 
if(c==2){falg=0; 
for(++N;fread(&pro[N],sizeof(STU),1,fp)!=0;N++) 
if(N>arrysize){ 
pro=(STU*)realloc(pro,sizeof(STU)*(arrysize+size));  //超出内存,就分配新的内存。 
} 
arrysize+=size; 
N--;     //跳出循环,N实际比得到人数要大一,故要减一。 
fclose(fp); 
showlist(); 
}  
} 
 
 
void abc(int s) //信息保存判断函数 s代表要进行的相应操作。 
{ char v[10]; 
if(N!=0&&falg!=1) 
{ 
 printf("新建信息尚未保存!,继续将会使新建的信息消失,"); 
 printf("是否先保存(y/n):"); 
 while(1){ 
gets(v); 
if(v[0]=='y'||v[0]=='Y') {save();break;} 
if(v[0]=='n'||v[0]=='N') break; 
else printf("输入有误!请重新输入:"); 
 } 
} 
if(s==1){ 
printf("请输入统计人的个数:"); 
 scanf("%d",&N); 
gets(v); //消除违规数据。 
for(int i=1;i<=N;i++) 
 newsect(i); 
} 
else return; 
} 
 
 
void main() //主函数 
{ char v[10]; 
 int choice,c; 
pro=(STU*)malloc(size*sizeof(STU)); 
if(pro==NULL) 
{ 
printf("内存分配出错!\n"); 
return; 
} 
printf("\t\t\t\t学生成绩管理系统\n\n"); 
do 
{ choice=-1;  
printf("\n0.新建\t\t1.添加\t\t\t2.查找\t3.删除\n4.列表输出\t5.排序\t\t\t6修改\n7.文件保存\t8.读取保存的记录文件\t9退出\n请选择相应的操作:"); 
scanf("%d",&choice); 
gets(v);  //消除违规数据,防止变成死循环 
switch(choice) 
{case 0:abc(1);break; 
case 1:++N;newsect(N);break; 
case 2:lookout();break; 
case 3:remove();break; 
case 6:change();het(1,N,1);break; 
case 5:if(N==0){printf("记录为空!\n");break;} 
 else {printf("1.按成绩降序 2.按成绩升序 3.按学号升序 4.按学号降序\n请选择相应功能:"); 
 scanf("%d",&c);het(1,N,c);} 
case 4:showlist();break; 
case 7:save();break; 
case 8:loadrecords();break; 
case 9:abc(0);printf("谢谢使用!\n");break; 
default:printf("选择无效!\n");break; 
} 
} 
while(choice!=9); 
}

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站栏目:C语言学生成绩管理系统课程设计-创新互联
文章地址:http://cdxtjz.cn/article/dccoop.html

其他资讯