⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 3.c

📁 C++开发的高校成绩管理
💻 C
📖 第 1 页 / 共 2 页
字号:
   
   
  printf("输入要删除的学生的学号:"); 
  scanf("%d",&number); 
  getchar(); 
 } 
#ifdef DEBUG  
 printf("已经退出了!\n"); 
#endif 
printf("现在的学生数为:%d个!\n",n); 
 return(head); 
}  

 /*============================================================================= 
=================*/ 
 /*============================================================================= 
=================*/ 
void print2311(score *head) 
/*函数print2311,功能:显示学生成绩*/ 
{ 
 score *p; 
 if(head==NULL)       
         {printf("\n没有任何学生资料!\n");} 
 else 
 {printf("%d\n",n); 
 printf("-----------------------------------------\n"); 
 printf("|学号\t|姓名\t|语文\t|英语\t|数学\t|\n"); 
 printf("-----------------------------------------\n");/*打印表格域*/ 
 p=head; 
     do 
    {printf("|%d\t|%s\t|%.1f\t|%.1f\t|%.1f\t|\n",p->number,p->name,p->yuwen,p-> 
yingyu,p->shuxue); 
        printf("-----------------------------------------\n");/*打印表格域*/ 
       p=p->next;}while (p!=NULL);/*打印完成了*/ 
 } 
} 
/*============================================================================== 
================*/ 
/*============================================================================== 
================*/ 
 score *statistics2311(score *head) 
  /*函数statistics2311,功能:统计学生成绩*/ 
 { 
  float sum1=0,sum2=0,sum3=0,ave1=0,ave2=0,ave3=0,max=0,min; 
  score *p; 
  int x,y=0,i=0; 

       p=head; 
       printf("1个人总分和平均分\t2单科平均分\t3总分最高分\t4总分最低分\n"); 
         scanf("%d",&x); 
      getchar(); 

 switch(x) 
  /*用switch语句实现功能选择*/ 
 { 
 case 1: if(head==NULL) 
     {printf("\n没有任何学生资料!\n");return(head);}/*链表为空*/ 
       else 
  { 
     printf("---------------------------------------------------------\n"); 
        printf("|学号\t|姓名\t|语文\t|英语\t|数学\t|总分\t|平均分\t|\n"); 
        printf("---------------------------------------------------------\n");/* 
打印表格域*/ 
     while(p!=NULL) 
     { 
      sum1=p->yuwen+p->yingyu+p->shuxue;  /*计算个人总分*/                       
       
               ave1=sum1/3;/*计算个人平均分*/ 
           
               printf("|%d\t|%s\t|%.1f\t|%.1f\t|%.1f\t|%.1f\t|%.1f\t|\n",p-> 
number,p->name,p->yuwen,p->yingyu,p->shuxue,sum1,ave1); 
      /*打印结果*/ 
               printf("--------------------------------------------------------- 
\n");/*打印表格域*/ 
         p=p->next;} 
    } 
           return(head);    break; 

  case 2: if(head==NULL) 
            {printf("\n没有任何学生资料!\n");return(head);}/*链表为空*/ 
       while(p!=NULL) 
         {  
    sum1=sum1+p->yuwen; 
    sum2=sum2+p->yingyu; 
    sum3=sum3+p->shuxue;/*计算总分*/ 
    y=y+1; 
                ave1=sum1/y; 
                ave2=sum2/y; 
                ave3=sum3/y;/*计算平均分*/ 
    p=p->next;/*使p指向下一个结点*/ 
          } 
     printf("语文平均分是%.1f\n",ave1); 
     printf("英语平均分是%.1f\n",ave2); 
     printf("数学平均分是%.1f\n",ave3);/*打印结果*/ 
             return(head); break; 
  case 3:  
   if(head==NULL) 
            {printf("\n没有任何学生资料!\n");return(head);}/*链表为空*/ 
       max=p->yuwen+p->yingyu+p->shuxue; 
   while(i<n) 
  {    
    i=i+1; 
    sum1=p->yuwen+p->yingyu+p->shuxue;  /*计算个人总分*/ 
        if(max<sum1) 
  max=sum1; 
  p=p->next; 
  } 
     
   printf("总分最高分:%.1f",max); 
   printf("\n"); 
   return(head); break; 


   
  case 4: if(head==NULL) 
     {printf("\n没有任何学生资料!\n");return(head);}/*链表为空*/ 
      while(p!=NULL) 
   { 
       min=p->yuwen+p->yingyu+p->shuxue; 
    while(p!=NULL) 
    {sum2=p->yuwen+p->yingyu+p->shuxue;  
    
    if(min>sum2) 
     min=sum2; 
     p=p->next; 
    } 
   } 
   
      printf("总分最低分:%.1f",min); 
      printf("\n"); 
      return(head); break; 
  
  default :printf("输入错误,请重试!\n"); 
 } 
 return(head); 
  
 } 


/*============================================================================== 
================*/ 
/*============================================================================== 
================*/ 

save2311(score *p1)  
/*函数save2311,功能:保存学生的资料*/ 
{  
 FILE *fp; 
  
 char filepn[20];/*用来存放文件保存路径以及文件名*/ 
  
 printf("请输入文件路径及文件名:"); 
 scanf("%s",filepn); 
 if((fp=fopen(filepn,"w+"))==NULL) 
 { 
  printf("不能打开文件!\n"); 
  return 0; 
 } 

    fprintf(fp,"            考试成绩管理系统             \n"); 
 fprintf(fp,"  作者:周纯钢 班级:  信息023   学号:11 \n"); 
    fprintf(fp,"-----------------------------------------\n"); 
 fprintf(fp,"|学号\t|姓名\t|语文\t|英语\t|数学\t|\n"); 
    fprintf(fp,"-----------------------------------------\n"); 
 /*打印表格域*/ 
 while(p1!=NULL) 
 { 
 fprintf(fp,"%d\t%s\t%.1f\t%.1f\t%.1f\t\n",p1->number,p1->name,p1->yuwen,p1-> 
yingyu,p1->shuxue); 
  
  p1=p1->next;/*下移一个结点*/ 
  
 } 
 fclose(fp); 
 printf("文件已经保存!\n"); 
 return 0; 
} 
/*============================================================================== 
================*/ 
/*============================================================================== 
================*/ 
 score *taxis2311(score *head)     
  /*定义排序函数。此函数带回一个指向链表头的指针*/ 
{ score *p,*max; 
  int   i,j,x; 
  float fen; 
  char t[10]; 
  if(head==NULL) 
  {printf("\n没有任何学生资料,请先建立链表!\n");return(head);}/*链表为空*/ 
  max=p=head; 
   
  for(i=0;i<80;i++) 
  printf("*"); 
    printf("1按学生学号排序\t2按学生姓名排序\t3按语文成绩排序\n"); 
    printf("4按英语成绩排序\t5按数学成绩排序\t\n"); 
  for(i=0;i<80;i++) 
  printf("*"); 
   
    printf("请选择操作:"); 
    scanf("%d",&x);/*选择操作*/ 
    getchar(); 

  switch(x) /*用switch语句实现功能选择*/ 
  {case 1 :   
               for(i=1;i<n;i++) 
               { 
             for(j=i+1;j<=n;j++) 
                 { 
       max=p; 
       p=p->next; 
       
       if(max->number>p->number) 
        { 
        k=max->number; 
        max->number=p->number; 
        p->number=k; 
         /*交换前后结点中的学号值,使得学号大者移到后面的结点中*/ 
         
        strcpy(t,max->name); 
        strcpy(max->name,p->name); 
        strcpy(p->name,t); 
     /*交换前后结点中的姓名,使之与学号相匹配*/ 
        fen=max->yuwen; 
        max->yuwen=p->yuwen; 
        p->yuwen=fen; 
                 /*交换前后结点中的语文成绩,使之与学号相匹配*/ 
       
        fen=max->yingyu; 
        max->yingyu=p->yingyu; 
        p->yingyu=fen; 
    /*交换前后结点中的英语成绩,使之与学号相匹配*/ 
        
        fen=max->shuxue; 
        max->shuxue=p->shuxue; 
        p->shuxue=fen; 
                /*交换前后结点中的数学成绩,使之与学号相匹配*/ 
        } 

                 } 
    max=head;p=head;/*重新使max,p指向链表头*/ 
             } 
                print2311(head);break;/*打印值排序后的链表内容*/ 

   case 2 :   for(i=1;i<n;i++) 
                { 
    for(j=i+1;j<=n;j++) 
                 { 
     max=p; 
        p=p->next; 
      if(strcmp(max->name,p->name)>0)/*strcmp=>字符串比较函数*/ 
        { 
       strcpy(t,max->name);/*strcpy=>字符串复制函数*/ 
       strcpy(max->name,p->name); 
       strcpy(p->name,t); 
  /*交换前后结点中的姓名,使得姓名字符串的值大者移到后面的结点中*/    
       k=max->number; 
       max->number=p->number; 
       p->number=k; 

   /*交换前后结点中的学号值,使之与姓名相匹配*/    fen=max->yuwen; 
       max->yuwen=p->yuwen; 
       p->yuwen=fen; 
    /*交换前后结点中的语文成绩,使之与姓名相匹配*/ 

       fen=max->yingyu; 
       max->yingyu=p->yingyu; 
       p->yingyu=fen; 
   /*交换前后结点中的英语成绩,使之与姓名相匹配*/ 

       fen=max->shuxue; 
       max->shuxue=p->shuxue; 
       p->shuxue=fen; 
   /*交换前后结点中的数学成绩,使之与姓名相匹配*/ 
        } 
                 } 
                  p=head; 
            max=head; 
                } 
                print2311(head); 
    break; 

   case 3 :     for(i=1;i<n;i++) 
                {for(j=i+1;j<=n;j++) 
                 {max=p; 
      p=p->next; 
      if(max->yuwen>p->yuwen) 
        { 
       fen=max->yuwen; 
          max->yuwen=p->yuwen; 
          p->yuwen=fen; 
 /*交换前后结点中的语文成绩,使得语文成绩高者移到后面的结点中*/ 
                      
       k=max->number; 
      max->number=p->number; 
      p->number=k;  
  /*交换前后结点中的学号,使之与语文成绩相匹配*/ 

                     strcpy(t,max->name); 
      strcpy(max->name,p->name); 
      strcpy(p->name,t); 
  /*交换前后结点中的姓名,使之与语文成绩相匹配*/ 

          fen=max->yingyu; 
       max->yingyu=p->yingyu; 
       p->yingyu=fen; 
  /*交换前后结点中的英语成绩,使之与语文成绩相匹配*/ 

       fen=max->shuxue; 
       max->shuxue=p->shuxue; 
       p->shuxue=fen; 
    /*交换前后结点中的数学成绩,使之与语文成绩相匹配*/ 
        } 
                 } 
                  p=head; 
            max=head; 
                } 
                print2311(head); 
    break; 

   case 4 :      for(i=1;i<n;i++) 
                {for(j=i+1;j<=n;j++) 
                 {max=p; 
      p=p->next; 
      if(max->yingyu>p->yingyu) 
        { 
      fen=max->yingyu; 
         max->yingyu=p->yingyu; 
         p->yingyu=fen; 
 /*交换前后结点中的英语成绩,使得英语成绩高者移到后面的结点中*/ 
       
      k=max->number; 
      max->number=p->number; 
      p->number=k; 
 /*交换前后结点中的学号,使之与英语成绩相匹配*/ 

         strcpy(t,max->name); 
      strcpy(max->name,p->name); 
      strcpy(p->name,t); 
  /*交换前后结点中的姓名,使之与英语成绩相匹配*/ 

         fen=max->yuwen; 
      max->yuwen=p->yuwen; 
      p->yuwen=fen; 
 /*交换前后结点中的语文成绩,使之与英语成绩相匹配*/ 
         fen=max->shuxue; 
      max->shuxue=p->shuxue; 
      p->shuxue=fen; 
 /*交换前后结点中的数学成绩,使之与英语成绩相匹配*/ 
        } 
                 } 
                  p=head; 
            max=head; 
                } 
               print2311(head); 
    break; 

   case 5 :      for(i=1;i<n;i++) 
                {for(j=i+1;j<=n;j++) 
                 {max=p; 
      p=p->next; 
      if(max->shuxue>p->shuxue) 
        { 
      fen=max->shuxue; 
         max->shuxue=p->shuxue; 
         p->shuxue=fen;  
      /*交换前后结点中的数学成绩,使得数学成绩高者移到后面的结点中*/ 

      k=max->number; 
      max->number=p->number; 
      p->number=k;  
      /*交换前后结点中的学号,使之与数学成绩相匹配*/ 

         strcpy(t,max->name); 
      strcpy(max->name,p->name); 
      strcpy(p->name,t);  
      /*交换前后结点中的姓名,使之与数学成绩相匹配*/ 

         fen=max->yuwen; 
      max->yuwen=p->yuwen; 
      p->yuwen=fen; 
      /*交换前后结点中的语文成绩,使之与数学成绩相匹配*/ 


         fen=max->yingyu; 
      max->yingyu=p->yingyu; 
      p->yingyu=fen; 
      /*交换前后结点中的英语成绩,使之与数学成绩相匹配*/ 
        } 
     } 
                  p=head; 
            max=head; 
                } 
                print2311(head); 
    break; 

    
   default :printf("输入错误,请重试! \n"); 
  } 
     return (0);} 

  

/*============================================================================== 
================*/ 
/*============================================================================== 
================*/ 
int menu2311(k)/*函数menu2311,功能:菜单选择界面*/ 
{ 
 int i; 
 printf("\t\t\t\t考试成绩管理系统\n"); 
 printf("\t\t\t作者:周纯钢  班级:信息023  学号:11\n"); 
    for(i=0;i<80;i++) 
         printf("*"); 
printf("1输入学生的资料\t\t\t2从文件调入资料\t\t\t3查询学生的成绩\n"); 
printf("4删除学生的资料\t\t\t5追加学生的资料\t\t\t6显示学生的成绩\n");  
printf("7统计学生的成绩\t\t\t8保存输入的资料\t\t\t9对成绩进行排序\n"); 
/*菜单选择界面*/  

for(i=0;i<80;i++) 
    printf("*"); 
printf("欢迎进入成绩管理系统,请选择您所要的操作(选择(0)退出):"); 
scanf("%d",&k);/*选择操作*/ 
   getchar(); 
  
return (k);} 


/*============================================================================== 
================*/ 
/*============================================================================== 
================*/ 
void main() /*主函数main,功能:通过调用creat,search,del,add,print,ststistics 
,save,taxis等函数,实现学生成绩查询系统功能*/ 
{score *head=0,*stu=0; 

while(1) 
{k=menu2311(k); 
switch(k)/*用switch语句实现功能选择*/ 
{case 1: head=creat2311();break;/*调用创建链表函数*/ 
 case 2: head=load2311(head);break;/*从文件调入记录函数*/ 
 case 3: head=search2311(head);break;/*调用成绩查询函数*/  
 case 4: head=del2311(head); break;/*调用删除学生资料函数*/ 
 case 5: head=add2311(head,stu);break;/*调用追加学生资料函数*/ 
 case 6: print2311(head); break;/*调用显示学生资料函数*/ 
 case 7: statistics2311(head); break;/*调用统计函数*/ 
 case 8: save2311(head);break;/*调用保存函数*/ 
 case 9: taxis2311(head);break;/*调用排序函数*/   
 case 0: exit(0);/*退出系统,返回主界面*/ 
 default: printf("输入错误,请重试!\n"); 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -