欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績管理系統(tǒng)

 更新時(shí)間:2018年01月15日 09:57:54   作者:雨晨可愛多  
這篇文章主要為大家詳細(xì)介紹了C語言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

要求:

某班有最多不超過30人(具體人數(shù)由鍵盤輸入)參加期末考試,最多不超過6門(具體門數(shù)由鍵盤輸入)。定義結(jié)構(gòu)體類型描述學(xué)生信息,每個(gè)學(xué)生信息包括:學(xué)號(hào)、姓名、多門課的成績、總成績和平均成績。用結(jié)構(gòu)體數(shù)組作為函數(shù)參數(shù),編程實(shí)現(xiàn)如下菜單驅(qū)動(dòng)的學(xué)生成績管理系統(tǒng)。
(1) 錄入每個(gè)學(xué)生的學(xué)號(hào)、姓名和各科考試成績。
(2) 計(jì)算每門課程的總分和平均分。
(3) 計(jì)算每個(gè)學(xué)生的總分和平均分。
(4) 按每個(gè)學(xué)生的總分由高到低排出名次表。
(5) 按學(xué)號(hào)由小到大排出成績表。
(6) 按姓名的字典順序排出成績表。
(7) 按學(xué)號(hào)查詢學(xué)生排名極其考試成績。
(8) 按姓名查詢學(xué)生排名極其考試成績。
(9) 按優(yōu)秀(90~100)、良好(80~90)、中等(70~80)、及格(60~70)、不及格(0~59)5個(gè)類別,對(duì)每門課程分別統(tǒng)計(jì)每個(gè)類別的人數(shù)以及所占的百分比。
(10) 輸出每個(gè)學(xué)生的學(xué)號(hào)、姓名、各科考試成績以及每門課程的總分和平均分。

代碼:

#include<stdio.h>
#include<Windows.h>
#include<conio.h>

#define SN 30 //學(xué)生人數(shù)
#define CN 6 //科目數(shù)
#define NL 20 //名字字節(jié)長度

typedef struct student{
 long int num;
 char name[NL];
 float score[CN];
 float sum;
 float aver;
}STU;

STU s[SN];
int itemSelected=-1;
int n=0;//學(xué)生數(shù)
int m=0;//課程數(shù)

int Menu();//菜單
void chose(int itemSelected);//選擇
void inputScore();//輸入分?jǐn)?shù)
void AverofC();//計(jì)算每門課程平均數(shù)
void AverofS();//每名學(xué)生總分和平均分
void sortByNum();//學(xué)生總分排行
void sortByGrade();
void sortByName();
void findByNum();
void findByName();
void statisticsAnalysis();
void printScore();

void main(){
 printf("請(qǐng)輸入學(xué)生總數(shù)(n<%d):\n",SN);
 scanf("%d",&n);
 printf("請(qǐng)輸入課程總數(shù)(m<%d):\n",CN);
 scanf("%d",&m);
 while(1){
 itemSelected=Menu();
 chose(itemSelected);
 itemSelected=-1;
 }
}

int Menu(){
 int itemSelected;
 system("cls");
 printf("\n ==============學(xué)生成績管理系統(tǒng)===============\n");
 printf("\t 1.輸入學(xué)號(hào)、姓名及各科成績\n");
 printf("\t 2.計(jì)算每門課程總分和平均分\n");
 printf("\t 3.計(jì)算每個(gè)學(xué)生總分和平局分\n");
 printf("\t 4.按每個(gè)學(xué)生總分高低排出名次表\n");
 printf("\t 5.按學(xué)號(hào)從小到大排出成績表\n");
 printf("\t 6.按學(xué)生字典順序排出成績表\n");
 printf("\t 7.按學(xué)號(hào)查詢學(xué)生排名和考試成績\n");
 printf("\t 8.按姓名查詢學(xué)生排名和成績\n");
 printf("\t 9.結(jié)果分析\n");
 printf("\t 10.輸出信息\n");
 printf("\t 0.退出\n");
 printf("===============================================\n");
 printf("請(qǐng)選擇選項(xiàng):");
 scanf("%d",&itemSelected);
 return itemSelected;
}

void chose(int itemSelected){
 switch(itemSelected){
 case 1: inputScore(); break;
 case 2: AverofC();break;
 case 3: AverofS();break;
 case 4: sortByGrade();break;
 case 5: sortByNum();break;
 case 6: sortByName();break;
 case 7: findByNum();break;
 case 8: findByName();break;
 case 9: statisticsAnalysis();break;
 case 10: printScore();break;
 case 0: exit(0);
 printf("即將退出程序");break;
 default: printf("輸入錯(cuò)誤!");break;
 }
}

void inputScore(){
 printf("\n===============================================\n");
 printf("請(qǐng)輸入學(xué)生學(xué)號(hào)、姓名及各科信息(輸入0停止信息輸入)\n");
 for(int i=0;i<n;i++){
 printf("學(xué)號(hào)(8位)");
 scanf("%ld",&s[i].num);
 if(s[i].num==0) break;
 getchar();//吸收多余換行符
 printf("姓名");
 gets(s[i].name);
 printf("請(qǐng)輸入各科成績");
 s[i].sum=0;
 for(int j =0;j<m;j++){
  scanf("%f",&s[i].score[j]);
  s[i].sum +=s[i].score[j];
 }
 }
}

void AverofC(){
 float sum[CN]={0};
 float average[CN]={0};
 for(int i=0;i<m;i++){
 for(int j=0;j<n;j++){
 sum[i]+=s[j].score[i];
 }
 average[i]=sum[i]/n;
 printf("第%d門課程的總分為:%.2f,平均分為%.2f\n",i+1,sum[i],average[i]);
 } 
 getch();
}

void AverofS(){
 float sum[SN]={0};
 float average[SN]={0};
 for (int i=0;i<n;i++){
 for(int j=0;j<m;j++){
  sum[i]+=s[i].score[j];
 }
 average[i]=sum[i]/m;
 printf("第%d個(gè)學(xué)生的總分為:%.2f,平均分為%.2f\n",i+1,sum[i],average[i]);
 }
 getch();
}

void sortByNum(){
 //按學(xué)號(hào)從小到大排序
 STU temp1={0};
 for(int i=0;i<n-1;i++){
 if(s[i].num>s[i+1].num){
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n==============按學(xué)號(hào)從小到排序===============\n");
 for(int j=0;j<n;j++){
 printf("該學(xué)生的學(xué)號(hào)為:%d\n",s[j].num);
 printf("該學(xué)生的姓名為:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n該學(xué)生的各科成績?yōu)閈n");
 for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[j].score[c]);
 }
 printf("\n");
 }
 getch();
}

void sortByGrade(){
 //按總分從高到低排序
 STU temp1={0};
 for(int i=0;i<n-1;i++){
  if(s[i].sum<s[i+1].sum){
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n============按總成績從高到低排序===========\n");
 for(int j=0;j<n;j++){
 printf("該學(xué)生的學(xué)號(hào)為:%d\n",s[j].num);
 printf("該學(xué)生的姓名為:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n該學(xué)生的各科成績?yōu)閈n");
 for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[j].score[c]);
 }
 printf("該學(xué)生的總成績?yōu)?%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

void sortByName(){
 //按姓名首字母字典順序排序
 STU temp1={0}; 
 for(int i=0;i<n-1;i++){
  if(((int)(s[i].name[0])>(int)(s[i+1].name[0]))){
  //將名字首字母轉(zhuǎn)成成ASCII碼從而比較大小排序
  temp1=s[i];
  s[i]=s[i+1];
  s[i+1]=temp1;
 }
 }
 printf("\n==============按學(xué)號(hào)從小到排序===============\n");
 for(int j=0;j<n;j++){
 printf("該學(xué)生的學(xué)號(hào)為:%d\n",s[j].num);
 printf("該學(xué)生的姓名為:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n該學(xué)生的各科成績?yōu)閈n");
 for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[j].score[c]);
 }
 printf("該學(xué)生的總成績?yōu)?%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

void findByNum() {
 int find=-1;
 //記錄需要查找的學(xué)號(hào),并作為查找成功與否的標(biāo)識(shí)符
 printf("請(qǐng)輸入要查找的學(xué)號(hào):");
 scanf("%d",&find);
 for(int i=0;i<n;i++){
 if(s[i].num==find){
  printf("\n查找成功\n");
  printf("該學(xué)生的學(xué)號(hào)為%d\n",s[i].num);
  printf("該學(xué)生的姓名為:");
  for(int k=0;k<NL;k++){
  printf("%c",s[i].name[k]);
  }
  printf("\n該學(xué)生的各科成績?yōu)閈n");
  for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[i].score[c]);
  }
  printf("該學(xué)生的總成績?yōu)?%.2f",s[i].sum);
  printf("\n");
  find=-2;
 }
 }
 if(find!=-2){
 printf("查無此人\n");
 printf("按任意鍵繼續(xù)");
 }
 getch();
}

void findByName(){
 int is_find=0;
 char find[SN];
 printf("請(qǐng)輸入要查找的姓名:");
 getchar();
 gets(find);
 for(int i=0;i<n;i++){
 if(strcmp(s[i].name,find)==0){
  printf("\n查找成功\n");
  printf("該學(xué)生的學(xué)號(hào)為%d\n",s[i].num);
  printf("該學(xué)生的姓名為:");
  for(int k=0;k<NL;k++){
  printf("%c",s[i].name[k]);
  }
  printf("\n該學(xué)生的各科成績?yōu)閈n");
  for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[i].score[c]);
  }
  printf("該學(xué)生的總成績?yōu)?%.2f",s[i].sum);
  printf("\n");
  is_find=1;
 }
 }
 if(is_find!=1){
 printf("查無此人\n");
 printf("按任意鍵繼續(xù)");
 }
 getch();
}

void statisticsAnalysis(){
 printf("輸出每門課程優(yōu)秀、良好、中等、及格、不及格人數(shù)所占的百分比\n");
 int a1[CN]={0},a2[CN]={0},a3[CN]={0},a4[CN]={0},a5[CN]={0};
 for(int i=0;i<n;i++){
 for(int j=0;j<m;j++){
  if(s[i].score[j]>=90 && s[i].score[j]<=100){
  a1[j]++;
  }else if (s[i].score[j]>=80 && s[i].score[j]<90){
  a2[j]++;
  }else if (s[i].score[j]>=70 && s[i].score[j]<80){
  a3[j]++;
  }else if (s[i].score[j]>=60 && s[i].score[j]<70){
  a4[j]++;
  }else if (s[i].score[j]<60){
  a5[j]++;
  }
 }
 }
 printf("\n====================各們課程概況==================\n");
 for(int k=0;k<m;k++){
  printf("第%d門課的優(yōu)秀人數(shù)占%.2f%%,",k+1,(a1[k]/(n*1.0))*100);
  printf("良好人數(shù)占%.2f%%,",(a2[k]/(n*1.0))*100);
  printf("中等人數(shù)占%.2f%%,",(a3[k]/(n*1.0))*100);
  printf("及格人數(shù)占%.2f%%,",(a4[k]/(n*1.0))*100);
  printf("不及格人數(shù)占%.2f%%,",(a5[k]/(n*1.0))*100);

  printf("\n");
 }
 getch();
}

void printScore(){
 printf("==============以下為學(xué)生信息==============");
 for(int j=0;j<n;j++){
 printf("該學(xué)生的學(xué)號(hào)為:%d\n",s[j].num);
 printf("該學(xué)生的姓名為:");
 for(int k=0;k<NL;k++){
  printf("%c",s[j].name[k]);
 }
 printf("\n該學(xué)生的各科成績?yōu)閈n");
 for(int c=0;c<m;c++){
  printf("第%d門成績?yōu)?.2f\n",c+1,s[j].score[c]);
 }
 printf("該學(xué)生的總成績?yōu)?%.2f",s[j].sum);
 printf("\n");
 }
 getch();
}

更多學(xué)習(xí)資料請(qǐng)關(guān)注專題《管理系統(tǒng)開發(fā)》。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語言快速排序函數(shù)用法(qsort)

    C語言快速排序函數(shù)用法(qsort)

    這篇文章主要為大家詳細(xì)介紹了C語言的快排函數(shù)用法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • C++中的STL常用算法之遍歷算法詳解

    C++中的STL常用算法之遍歷算法詳解

    這篇文章主要介紹了C++中的STL常用算法之遍歷算法詳解,ransform() 可以將函數(shù)應(yīng)用到容器的元素上,并將這個(gè)函數(shù)返回的值保存到另一個(gè)容器中,它返回的迭代器指向輸出容器所保存的最后一個(gè)元素的下一個(gè)位置,需要的朋友可以參考下
    2023-12-12
  • C語言與C++中關(guān)于字符串使用的比較

    C語言與C++中關(guān)于字符串使用的比較

    字符串是我們?cè)偈煜げ贿^的東西了,任何語言中字符串都是基礎(chǔ)都要經(jīng)常用到,那么在不同語言中字符串的用法一樣嗎?下面我們來看看C語言與C++中字符串使用的比較
    2022-05-05
  • 使用OpenGL繪制Bezier曲線

    使用OpenGL繪制Bezier曲線

    這篇文章主要為大家詳細(xì)介紹了使用OpenGL繪制Bezier曲線的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++面試題之?dāng)?shù)a、b的值互換(不使用中間變量)

    C++面試題之?dāng)?shù)a、b的值互換(不使用中間變量)

    這篇文章主要介紹了不使用中間變量,C++實(shí)現(xiàn)數(shù)a、b的值互相轉(zhuǎn)換操作,感興趣的小伙伴們可以參考一下
    2016-07-07
  • C語言 structural body結(jié)構(gòu)體詳解用法

    C語言 structural body結(jié)構(gòu)體詳解用法

    C 數(shù)組允許定義可存儲(chǔ)相同類型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許您存儲(chǔ)不同類型的數(shù)據(jù)項(xiàng),結(jié)構(gòu)用于表示一條記錄,假設(shè)您想要跟蹤圖書館中書本的動(dòng)態(tài),您可能需要跟蹤每本書的下列屬性
    2021-10-10
  • C語言實(shí)現(xiàn)簡單停車場(chǎng)管理系統(tǒng)

    C語言實(shí)現(xiàn)簡單停車場(chǎng)管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)簡單停車場(chǎng)管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • OpenCV c++滑動(dòng)條的創(chuàng)建和使用代碼

    OpenCV c++滑動(dòng)條的創(chuàng)建和使用代碼

    滾動(dòng)條(Trackbar)在OpenCV中是非常方便的交互工具,它依附于特定的窗口而存在,下面這篇文章主要給大家介紹了關(guān)于OpenCV?c++滑動(dòng)條的創(chuàng)建和使用的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • C語言實(shí)現(xiàn)二叉樹的搜索及相關(guān)算法示例

    C語言實(shí)現(xiàn)二叉樹的搜索及相關(guān)算法示例

    這篇文章主要介紹了C語言實(shí)現(xiàn)二叉樹的搜索及相關(guān)算法,結(jié)合具體實(shí)例形式分析了基于C語言創(chuàng)建、遍歷、搜索等相關(guān)算法與實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-06-06
  • C語言實(shí)現(xiàn)雙人反彈球游戲

    C語言實(shí)現(xiàn)雙人反彈球游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)雙人反彈球游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05

最新評(píng)論