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

C語(yǔ)言學(xué)生管理系統(tǒng)源碼分享

 更新時(shí)間:2017年03月24日 17:11:24   作者:豬豬_小  
這篇文章主要為大家分享了C語(yǔ)言學(xué)生管理系統(tǒng)的源碼,幫助大家學(xué)習(xí)結(jié)構(gòu)體,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語(yǔ)言學(xué)生管理系統(tǒng)源碼,供大家參考,具體內(nèi)容如下

#include<stdio.h> 
#include<stdlib.h> 
//結(jié)構(gòu)體可以存放的學(xué)生信息最大個(gè)數(shù),不可變變量
 int const MAX_LENGTH=100; 
 //學(xué)生信息結(jié)構(gòu)體數(shù)組,最多可以存放100個(gè)學(xué)生信息 
 struct student{
 int id; //學(xué)號(hào) 
 char *name; //姓名 
 int age; //年齡
 float c_score; //C語(yǔ)言成績(jī) 
 float english_score; //英語(yǔ)成績(jī) 
 float database_score; //數(shù)據(jù)庫(kù)成績(jī)
 float total_score; //總分 
 }student_array[MAX_LENGTH]; 
 
 //學(xué)生信息數(shù)量 
 int student_count=0; 

 //函數(shù)聲明 
 void print_all_students();
 void input_info(); 
 void query_info();
 void modify_info();
 void delete_info(); 
 void compute_total_score();
 void sort_info(); 
 int search_one_student(); 
 void print_one_student(struct student one);
 void delete_one_student(int student_index);
 char * get_item_name(int item_index);
 void modify_one_student(int student_index);
 void sort_by_id();
 void sort_by_c_score(); 
 void sort_by_english_score(); 
 void sort_by_database_score();

 //主函數(shù) 
 int main()
 {
 while(1)
 { 
 printf("請(qǐng)選擇要使用的功能:\n");
 printf("錄入信息,請(qǐng)輸入1,然后回車(chē)!\n");
 printf("查詢(xún)信息,請(qǐng)輸入2,然后回車(chē)!\n"); 
 printf("修改信息,請(qǐng)輸入3,然后回車(chē)!\n"); 
 printf("刪除信息,請(qǐng)輸入4,然后回車(chē)!\n"); 
 printf("計(jì)算總分,請(qǐng)輸入5,然后回車(chē)!\n"); 
 printf("排序信息,請(qǐng)輸入6,然后回車(chē)!\n"); 
 printf("輸出全部,請(qǐng)輸入0,然后回車(chē)!\n");
 printf("退出程序,請(qǐng)輸入-1,然后回車(chē)!\n"); 
 //函數(shù)選擇變量 
 int function=0;
 //輸入選擇的函數(shù)編號(hào)值 
 scanf("%d",&function); 
 //根據(jù)輸入的函數(shù)編號(hào),執(zhí)行對(duì)應(yīng)的功能
 switch(function){
 case -1: 
  exit(1);
 case 0: 
  print_all_students(); 
  break;
 case 1: 
  input_info();
  break;
 case 2:
  query_info();
  break; 
 case 3: 
  modify_info();
  break; 
 case 4: 
  delete_info();
  break; 
 case 5: 
  compute_total_score(); 
  break; 
 case 6:
  sort_info(); 
  break; 
 default: 
  printf("請(qǐng)輸入正確的功能編號(hào)!?。n\n");
  break;
 } 
 } 
 return 0; 
 } 
 
 //錄入信息函數(shù)
void input_info()
 {
 printf("當(dāng)前功能————錄入信息!\n"); 
 //判斷是否還有空間 
 if(student_count<MAX_LENGTH)
 {
 //聲明一些臨時(shí)變量
 int id=0; char *name=(char *)malloc(100);
 int age=0; float c_score=0; 
 float english_score=0;
 float database_score=0; 
 printf("請(qǐng)輸入學(xué)生信息,格式為:學(xué)號(hào),姓名,年齡,C語(yǔ)言成績(jī),英語(yǔ)成績(jī),數(shù)據(jù)庫(kù)成績(jī)\n");
 scanf("%d %s %d %f %f %f",&id,name,&age,&c_score,&english_score,&database_score);
 printf("學(xué)生信息校對(duì):學(xué)號(hào):%d,姓名:%s,年齡:%d,C語(yǔ)言成績(jī):%f,英語(yǔ)成績(jī):%f,數(shù)據(jù)庫(kù)成績(jī):%f\n",id,name,age,c_score,english_score,database_score); 
 //學(xué)生信息加入結(jié)構(gòu)體數(shù)組 
 student_array[student_count].id=id;
 student_array[student_count].name=name;
 student_array[student_count].age=age;
 student_array[student_count].c_score=c_score; 
 student_array[student_count].english_score=english_score; 
 student_array[student_count].database_score=database_score; 
 student_count++; 
 //是否繼續(xù)錄入信息
 printf("是否繼續(xù)錄入信息?繼續(xù)請(qǐng)輸入y,返回主菜單輸入n\n");
 char go_on; 
 scanf("%s",&go_on); 
 if(go_on=='y')
 { 
  input_info();
 } 
 }
 else
 { 
 printf("學(xué)生結(jié)構(gòu)體數(shù)據(jù)已滿(mǎn),可以刪除一部分學(xué)生信息!\n");
 }
 } 


 //查詢(xún)信息函數(shù) 
void query_info()
 {
 printf("當(dāng)前功能————查詢(xún)信息!\n");
 printf("請(qǐng)輸入學(xué)生的學(xué)號(hào)\n"); 
 int id=0; 
 scanf("%d",&id);
 //查找輸入id學(xué)生的序號(hào)
 int student_index=search_one_student(id);
 if(student_index!=-1)
 {
 print_one_student(student_array[student_index]); 
 }
 else
 { 
 printf("沒(méi)有該學(xué)號(hào)的學(xué)生!\n");
 } 
 //是否繼續(xù)查詢(xún)信息 
 printf("是否繼續(xù)查詢(xún)信息?繼續(xù)請(qǐng)輸入y,返回主菜單輸入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 query_info();
 } 
 
 
 //修改信息函數(shù)
void modify_info()
 { 
 printf("當(dāng)前功能————修改信息!\n");
 printf("請(qǐng)輸入學(xué)生的學(xué)號(hào)\n");
 int id=0; 
 scanf("%d",&id);
 //查找輸入id學(xué)生的序號(hào)
 int student_index=search_one_student(id);
 if(student_index!=-1)
 { 
 modify_one_student(student_index); 
 }
 else
 { 
 printf("沒(méi)有該學(xué)號(hào)的學(xué)生!\n");
 } 
} 
 
 
 //刪除信息函數(shù) 
void delete_info()
 { 
 printf("當(dāng)前功能————?jiǎng)h除信息!\n");
 printf("請(qǐng)輸入學(xué)生的學(xué)號(hào)\n"); 
 int id=0;
 scanf("%d",&id);
 //查找輸入id學(xué)生的序號(hào)
 int student_index=search_one_student(id);
 if(student_index!=-1)
 { 
 //防止student_index被改變,傳入temp_index計(jì)算
 int temp_index=student_index;
 print_one_student(student_array[temp_index]);
 //刪除前進(jìn)行確認(rèn)
 printf("確定刪除學(xué)號(hào) %d 同學(xué)的信息?繼續(xù)請(qǐng)輸入y\n",id);
 char be_true; 
 scanf("%s",&be_true);
 if(be_true=='y')
 { 
  printf("%d\n", student_index); 
  //執(zhí)行刪除動(dòng)作 
  delete_one_student(student_index); 
 } 
 }
 else
 { 
 printf("沒(méi)有該學(xué)號(hào)的學(xué)生!\n"); 
 } 
 //是否繼續(xù)刪除信息
 printf("是否繼續(xù)刪除信息?繼續(xù)請(qǐng)輸入y,返回主菜單輸入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 delete_info();
 } 
 
 
 //計(jì)算總分函數(shù) 
void compute_total_score()
 { 
 printf("當(dāng)前功能————計(jì)算總分!\n"); 
 for (int i = 0; i < student_count; ++i)
 { 
  student_array[i].total_score=student_array[i].c_score+student_array[i].english_score+student_array[i].database_score; 
  print_one_student(student_array[i]);
  printf("總成績(jī):%f\n", student_array[i].total_score);
 } 
 printf("總分計(jì)算完成?。?!\n");
 } 
 
 
 //成績(jī)排序函數(shù)
void sort_info()
 {
 printf("當(dāng)前功能————成績(jī)排序!\n"); 
 printf("排序前所有學(xué)生信息如下:\n");
 print_all_students();
 int sort_type;
 while(1)
 { 
 printf("請(qǐng)輸入排序字段,學(xué)號(hào):1,C語(yǔ)言成績(jī):2,英語(yǔ)成績(jī):3,數(shù)據(jù)庫(kù)成績(jī):4\n");
 scanf("%d",&sort_type);
 if(sort_type>=1&&sort_type<=4)
 break; 
 }
 switch(sort_type)
 { 
 case 1: 
 sort_by_id(); 
 break; 
 case 2:
 sort_by_c_score();
 break;
 case 3: 
 sort_by_english_score(); 
 break; 
 case 4: 
 sort_by_database_score(); 
 break;
 } 
 printf("排序后所有學(xué)生信息如下:\n");
 print_all_students(); 
 //是否繼續(xù)刪除信息 
 printf("是否繼續(xù)排序信息?繼續(xù)請(qǐng)輸入y,返回主菜單輸入n\n"); 
 char go_on;
 scanf("%s",&go_on);
 if(go_on=='y')
 sort_info();
 } 


//根據(jù)輸入的學(xué)號(hào),遍歷結(jié)構(gòu)體數(shù)組,若存在該學(xué)生,返回?cái)?shù)組下標(biāo),不存在返回-1
int search_one_student(int id)
 {
 for (int i = 0; i < student_count; ++i)
 { 
 if(student_array[i].id==id)
 { 
  return i;
 }
 } 
 return -1; 
 } 


//輸出某個(gè)學(xué)生的信息 
void print_one_student(struct student one)
{
 printf("學(xué)生信息:學(xué)號(hào):%d,姓名:%s,年齡:%d,C語(yǔ)言成績(jī):%f,英語(yǔ)成績(jī):%f,數(shù)據(jù)庫(kù)成績(jī):%f\n",one.id,one.name,one.age,one.c_score,one.english_score,one.database_score);
} 


//輸出所有學(xué)生的信息
void print_all_students()
{ 
 if(student_count==0)
 {
 printf("暫無(wú)學(xué)生信息\n\n\n");
 }
 for (int i = 0; i < student_count; ++i)
 { 
 print_one_student(student_array[i]);
 } 
} 


void modify_one_student(int student_index)
{ 
 //修改前,輸出學(xué)生信息 
 print_one_student(student_array[student_index]); 
 //字段序號(hào)初始值 
 int item_index=0; 
 //不允許修改學(xué)號(hào)字段 
 while(1)
 { 
 printf("請(qǐng)輸入要修改的字段序號(hào),姓名:1,年齡:2,C語(yǔ)言成績(jī):3,英語(yǔ)成績(jī):4,數(shù)據(jù)庫(kù)成績(jī):5\n"); 
 scanf("%d",&item_index); 
 if(item_index>=1&&item_index<=5)
 break; 
 } 
 switch(item_index)
 { 
 case 1: 
  printf("請(qǐng)輸入 %s 字段的新值\n", get_item_name(item_index)); 
  char* item_value_1=(char *)malloc(100);
  ; 
  scanf("%s",item_value_1);
  student_array[student_index].name=item_value_1;
  break;
 case 2:
  printf("請(qǐng)輸入 %s 字段的新值\n", get_item_name(item_index));
  int item_value_2; 
  scanf("%d",&item_value_2);
  student_array[student_index].age=item_value_2;
  break;
 case 3: 
  printf("請(qǐng)輸入 %s 字段的新值\n", get_item_name(item_index));
  float item_value_3;
  scanf("%f",&item_value_3); 
  student_array[student_index].c_score=item_value_3;
  break; 
 case 4:
  printf("請(qǐng)輸入 %s 字段的新值\n", get_item_name(item_index));
  float item_value_4;
  scanf("%f",&item_value_4); 
  student_array[student_index].english_score=item_value_4;
  break; 
 case 5:
  printf("請(qǐng)輸入 %s 字段的新值\n", get_item_name(item_index)); 
  float item_value_5;
  scanf("%f",&item_value_5); 
  student_array[student_index].database_score=item_value_5;
  break; 
 }
 printf("修改成功!新的學(xué)生信息如下:\n");
 //修改后輸出學(xué)生信息 
 print_one_student(student_array[student_index]);
 //是否繼續(xù)刪除信息 
 printf("是否繼續(xù)修改該學(xué)生信息?繼續(xù)請(qǐng)輸入y,返回主菜單輸入n\n");
 char go_on; 
 scanf("%s",&go_on);
 if(go_on=='y') 
 modify_one_student(student_index);
} 


//刪除數(shù)組對(duì)應(yīng)序號(hào)的學(xué)生信息,把i位置后面的數(shù)據(jù)組元素向前移動(dòng)覆蓋i,student_count計(jì)數(shù)器減1 
void delete_one_student(int student_index)
{
 for (int i = student_index; i < student_count-1; ++i) 
 { 
 student_array[i]=student_array[i+1]; 
 } 
 student_count--;
 printf("刪除完成\n\n\n"); 
} 


//根據(jù)輸入的字段序號(hào),返回字段名稱(chēng)
char * get_item_name(int item_index)
{ 
 switch(item_index)
 { 
 case 0:
  return "學(xué)號(hào)"; 
 case 1: 
  return "姓名"; 
 case 2:
  return "年齡";
 case 3:
  return "C語(yǔ)言成績(jī)"; 
 case 4:
  return "英語(yǔ)成績(jī)";
 case 5: 
  return "數(shù)據(jù)庫(kù)成績(jī)";
 default: 
  return "";
 } 
} 


//按照id排序,使用最簡(jiǎn)單的冒泡排序法
void sort_by_id()
{ 
 for (int i = 0; i < student_count; ++i)
 {
 for (int j = i; j < student_count; ++j) 
 { 
  if(student_array[i].id>student_array[j].id)
  {   
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j];
  student_array[j]=temp;
  } 
 } 
 } 
 printf("按照 學(xué)號(hào) 排序完成\n");
} 


//按照C語(yǔ)言成績(jī)排序,使用最簡(jiǎn)單的冒泡排序法
void sort_by_c_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 {
  if(student_array[i].c_score>student_array[j].c_score)
  { 
  struct student temp=student_array[i];
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  } 
 } 
 }
 printf("按照 C語(yǔ)言成績(jī) 排序完成\n");
} 


//按照英語(yǔ)成績(jī)排序,使用最簡(jiǎn)單的冒泡排序法 
void sort_by_english_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 { 
  if(student_array[i].english_score>student_array[j].english_score)
  { 
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  }
 }
 }
 printf("按照 英語(yǔ)成績(jī) 排序完成\n"); 
} 


//按照數(shù)據(jù)庫(kù)成績(jī)排序,使用最簡(jiǎn)單的冒泡排序法 
void sort_by_database_score()
{ 
 for (int i = 0; i < student_count; ++i)
 { 
 for (int j = i; j < student_count; ++j)
 {
  if(student_array[i].database_score>student_array[j].database_score)
  { 
  struct student temp=student_array[i]; 
  student_array[i]=student_array[j]; 
  student_array[j]=temp;
  } 
 }
 } 
 printf("按照 數(shù)據(jù)庫(kù)成績(jī) 排序完成\n");
}

關(guān)于管理系統(tǒng)的更多內(nèi)容請(qǐng)點(diǎn)擊《管理系統(tǒng)專(zhuān)題》進(jìn)行學(xué)習(xí)

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

相關(guān)文章

  • C++中delete函數(shù)的具體使用

    C++中delete函數(shù)的具體使用

    本文主要介紹了C++中delete函數(shù)的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • C++中4種強(qiáng)制類(lèi)型轉(zhuǎn)換的區(qū)別總結(jié)

    C++中4種強(qiáng)制類(lèi)型轉(zhuǎn)換的區(qū)別總結(jié)

    C++風(fēng)格的類(lèi)型轉(zhuǎn)換提供了4種類(lèi)型轉(zhuǎn)換操作符來(lái)應(yīng)對(duì)不同場(chǎng)合的應(yīng)用。下面這篇文章主要給大家介紹了C++中4種強(qiáng)制類(lèi)型轉(zhuǎn)換的區(qū)別,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2016-12-12
  • C++中的vector使用詳解及重要部分底層實(shí)現(xiàn)

    C++中的vector使用詳解及重要部分底層實(shí)現(xiàn)

    本篇文章會(huì)對(duì)vector的語(yǔ)法使用進(jìn)行詳解,同時(shí),還會(huì)對(duì)重要難點(diǎn)部分的底層實(shí)現(xiàn)進(jìn)行講解,其中有vector的迭代器失效和深拷貝問(wèn)題,希望本篇文章的內(nèi)容會(huì)對(duì)你有所幫助
    2023-07-07
  • C語(yǔ)言調(diào)試手段:鎖定錯(cuò)誤的實(shí)現(xiàn)方法

    C語(yǔ)言調(diào)試手段:鎖定錯(cuò)誤的實(shí)現(xiàn)方法

    本篇文章是對(duì)在C語(yǔ)言調(diào)試中,鎖定錯(cuò)誤的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • 深入理解strcpy與memcpy的區(qū)別

    深入理解strcpy與memcpy的區(qū)別

    本篇文章是對(duì)strcpy與memcpy的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C中qsort快速排序使用實(shí)例

    C中qsort快速排序使用實(shí)例

    在學(xué)習(xí)C++ STL的sort函數(shù),發(fā)現(xiàn)C中也存在一個(gè)qsort快速排序,要好好學(xué)習(xí)下C的庫(kù)函數(shù)啊
    2014-01-01
  • C++構(gòu)建函數(shù)使用介紹

    C++構(gòu)建函數(shù)使用介紹

    構(gòu)造函數(shù)主要作用在于創(chuàng)建對(duì)象時(shí)為對(duì)象的成員屬性賦值,構(gòu)造函數(shù)由編譯器自動(dòng)調(diào)用,無(wú)須手動(dòng)調(diào)用;析構(gòu)函數(shù)主要作用在于對(duì)象銷(xiāo)毀前系統(tǒng)自動(dòng)調(diào)用,執(zhí)行一 些清理工作
    2022-08-08
  • C++將保存char、int 和double到txt文件中

    C++將保存char、int 和double到txt文件中

    這篇文章主要介紹了C++如何將保存char、int 和double到txt文件中,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++中int?main(int?argc,?char**?argv)的參數(shù)使用

    C++中int?main(int?argc,?char**?argv)的參數(shù)使用

    int?main(int?argc,?char**?argv)?是C和C++程序的入口點(diǎn),其中argc和argv是用來(lái)接收從命令行傳遞給程序的參數(shù)的,本文就來(lái)介紹一下這兩個(gè)參數(shù)的含義,感興趣的可以了解一下的相關(guān)資料
    2024-01-01
  • C++ LeeCode題目:比特位計(jì)數(shù)和買(mǎi)賣(mài)股票的最佳時(shí)機(jī)

    C++ LeeCode題目:比特位計(jì)數(shù)和買(mǎi)賣(mài)股票的最佳時(shí)機(jī)

    這篇文章主要介紹了基于C語(yǔ)言計(jì)算比特位計(jì)數(shù)和買(mǎi)賣(mài)股票的最佳時(shí)機(jī),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-07-07

最新評(píng)論