C語言學(xué)生管理系統(tǒng)源碼分享
本文實(shí)例為大家分享了C語言學(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é)號 char *name; //姓名 int age; //年齡 float c_score; //C語言成績 float english_score; //英語成績 float database_score; //數(shù)據(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("請選擇要使用的功能:\n"); printf("錄入信息,請輸入1,然后回車!\n"); printf("查詢信息,請輸入2,然后回車!\n"); printf("修改信息,請輸入3,然后回車!\n"); printf("刪除信息,請輸入4,然后回車!\n"); printf("計(jì)算總分,請輸入5,然后回車!\n"); printf("排序信息,請輸入6,然后回車!\n"); printf("輸出全部,請輸入0,然后回車!\n"); printf("退出程序,請輸入-1,然后回車!\n"); //函數(shù)選擇變量 int function=0; //輸入選擇的函數(shù)編號值 scanf("%d",&function); //根據(jù)輸入的函數(shù)編號,執(zhí)行對應(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("請輸入正確的功能編號?。?!\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("請輸入學(xué)生信息,格式為:學(xué)號,姓名,年齡,C語言成績,英語成績,數(shù)據(jù)庫成績\n"); scanf("%d %s %d %f %f %f",&id,name,&age,&c_score,&english_score,&database_score); printf("學(xué)生信息校對:學(xué)號:%d,姓名:%s,年齡:%d,C語言成績:%f,英語成績:%f,數(shù)據(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ù)請輸入y,返回主菜單輸入n\n"); char go_on; scanf("%s",&go_on); if(go_on=='y') { input_info(); } } else { printf("學(xué)生結(jié)構(gòu)體數(shù)據(jù)已滿,可以刪除一部分學(xué)生信息!\n"); } } //查詢信息函數(shù) void query_info() { printf("當(dāng)前功能————查詢信息!\n"); printf("請輸入學(xué)生的學(xué)號\n"); int id=0; scanf("%d",&id); //查找輸入id學(xué)生的序號 int student_index=search_one_student(id); if(student_index!=-1) { print_one_student(student_array[student_index]); } else { printf("沒有該學(xué)號的學(xué)生!\n"); } //是否繼續(xù)查詢信息 printf("是否繼續(xù)查詢信息?繼續(xù)請輸入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("請輸入學(xué)生的學(xué)號\n"); int id=0; scanf("%d",&id); //查找輸入id學(xué)生的序號 int student_index=search_one_student(id); if(student_index!=-1) { modify_one_student(student_index); } else { printf("沒有該學(xué)號的學(xué)生!\n"); } } //刪除信息函數(shù) void delete_info() { printf("當(dāng)前功能————刪除信息!\n"); printf("請輸入學(xué)生的學(xué)號\n"); int id=0; scanf("%d",&id); //查找輸入id學(xué)生的序號 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é)號 %d 同學(xué)的信息?繼續(xù)請輸入y\n",id); char be_true; scanf("%s",&be_true); if(be_true=='y') { printf("%d\n", student_index); //執(zhí)行刪除動作 delete_one_student(student_index); } } else { printf("沒有該學(xué)號的學(xué)生!\n"); } //是否繼續(xù)刪除信息 printf("是否繼續(xù)刪除信息?繼續(xù)請輸入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("總成績:%f\n", student_array[i].total_score); } printf("總分計(jì)算完成?。。n"); } //成績排序函數(shù) void sort_info() { printf("當(dāng)前功能————成績排序!\n"); printf("排序前所有學(xué)生信息如下:\n"); print_all_students(); int sort_type; while(1) { printf("請輸入排序字段,學(xué)號:1,C語言成績:2,英語成績:3,數(shù)據(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ù)請輸入y,返回主菜單輸入n\n"); char go_on; scanf("%s",&go_on); if(go_on=='y') sort_info(); } //根據(jù)輸入的學(xué)號,遍歷結(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é)號:%d,姓名:%s,年齡:%d,C語言成績:%f,英語成績:%f,數(shù)據(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("暫無學(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]); //字段序號初始值 int item_index=0; //不允許修改學(xué)號字段 while(1) { printf("請輸入要修改的字段序號,姓名:1,年齡:2,C語言成績:3,英語成績:4,數(shù)據(jù)庫成績:5\n"); scanf("%d",&item_index); if(item_index>=1&&item_index<=5) break; } switch(item_index) { case 1: printf("請輸入 %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("請輸入 %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("請輸入 %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("請輸入 %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("請輸入 %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ù)請輸入y,返回主菜單輸入n\n"); char go_on; scanf("%s",&go_on); if(go_on=='y') modify_one_student(student_index); } //刪除數(shù)組對應(yīng)序號的學(xué)生信息,把i位置后面的數(shù)據(jù)組元素向前移動覆蓋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ù)輸入的字段序號,返回字段名稱 char * get_item_name(int item_index) { switch(item_index) { case 0: return "學(xué)號"; case 1: return "姓名"; case 2: return "年齡"; case 3: return "C語言成績"; case 4: return "英語成績"; case 5: return "數(shù)據(jù)庫成績"; default: return ""; } } //按照id排序,使用最簡單的冒泡排序法 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é)號 排序完成\n"); } //按照C語言成績排序,使用最簡單的冒泡排序法 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語言成績 排序完成\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("按照 英語成績 排序完成\n"); } //按照數(shù)據(jù)庫成績排序,使用最簡單的冒泡排序法 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ù)庫成績 排序完成\n"); }
關(guān)于管理系統(tǒng)的更多內(nèi)容請點(diǎn)擊《管理系統(tǒng)專題》進(jìn)行學(xué)習(xí)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C語言編寫學(xué)生成績管理系統(tǒng)
- 學(xué)生信息管理系統(tǒng)C語言版
- 學(xué)生成績管理系統(tǒng)C語言代碼實(shí)現(xiàn)
- C語言利用結(jié)構(gòu)體數(shù)組實(shí)現(xiàn)學(xué)生成績管理系統(tǒng)
- C語言實(shí)現(xiàn)簡單學(xué)生管理系統(tǒng)
- C語言學(xué)生成績管理系統(tǒng)源代碼
- C語言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(單鏈表)
- C語言數(shù)據(jù)結(jié)構(gòu)之學(xué)生信息管理系統(tǒng)課程設(shè)計(jì)
- C語言實(shí)現(xiàn)簡單學(xué)生學(xué)籍管理系統(tǒng)
- C語言實(shí)現(xiàn)學(xué)生管理系統(tǒng)總結(jié)
相關(guān)文章
C++中4種強(qiáng)制類型轉(zhuǎn)換的區(qū)別總結(jié)
C++風(fēng)格的類型轉(zhuǎn)換提供了4種類型轉(zhuǎn)換操作符來應(yīng)對不同場合的應(yīng)用。下面這篇文章主要給大家介紹了C++中4種強(qiáng)制類型轉(zhuǎn)換的區(qū)別,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-12-12C++中的vector使用詳解及重要部分底層實(shí)現(xiàn)
本篇文章會對vector的語法使用進(jìn)行詳解,同時(shí),還會對重要難點(diǎn)部分的底層實(shí)現(xiàn)進(jìn)行講解,其中有vector的迭代器失效和深拷貝問題,希望本篇文章的內(nèi)容會對你有所幫助2023-07-07C語言調(diào)試手段:鎖定錯(cuò)誤的實(shí)現(xiàn)方法
本篇文章是對在C語言調(diào)試中,鎖定錯(cuò)誤的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++中int?main(int?argc,?char**?argv)的參數(shù)使用
int?main(int?argc,?char**?argv)?是C和C++程序的入口點(diǎn),其中argc和argv是用來接收從命令行傳遞給程序的參數(shù)的,本文就來介紹一下這兩個(gè)參數(shù)的含義,感興趣的可以了解一下的相關(guān)資料2024-01-01C++ LeeCode題目:比特位計(jì)數(shù)和買賣股票的最佳時(shí)機(jī)
這篇文章主要介紹了基于C語言計(jì)算比特位計(jì)數(shù)和買賣股票的最佳時(shí)機(jī),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-07-07