C語言學生管理系統源碼分享。本站提示廣大學習愛好者:(C語言學生管理系統源碼分享)文章只能為提供參考,不一定能成為您想要的結果。以下是C語言學生管理系統源碼分享正文
本文實例為大家分享了C語言學生管理系統源碼,供大家參考,具體內容如下
#include<stdio.h>
#include<stdlib.h>
//結構體可以存放的學生信息最大個數,不可變變量
int const MAX_LENGTH=100;
//學生信息結構體數組,最多可以存放100個學生信息
struct student{
int id; //學號
char *name; //姓名
int age; //年齡
float c_score; //C語言成績
float english_score; //英語成績
float database_score; //數據庫成績
float total_score; //總分
}student_array[MAX_LENGTH];
//學生信息數量
int student_count=0;
//函數聲明
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();
//主函數
int main()
{
while(1)
{
printf("請選擇要使用的功能:\n");
printf("錄入信息,請輸入1,然後回車!\n");
printf("查詢信息,請輸入2,然後回車!\n");
printf("修改信息,請輸入3,然後回車!\n");
printf("刪除信息,請輸入4,然後回車!\n");
printf("計算總分,請輸入5,然後回車!\n");
printf("排序信息,請輸入6,然後回車!\n");
printf("輸出全部,請輸入0,然後回車!\n");
printf("退出程序,請輸入-1,然後回車!\n");
//函數選擇變量
int function=0;
//輸入選擇的函數編號值
scanf("%d",&function);
//根據輸入的函數編號,執行對應的功能
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;
}
//錄入信息函數
void input_info()
{
printf("當前功能————錄入信息!\n");
//判斷是否還有空間
if(student_count<MAX_LENGTH)
{
//聲明一些臨時變量
int id=0; char *name=(char *)malloc(100);
int age=0; float c_score=0;
float english_score=0;
float database_score=0;
printf("請輸入學生信息,格式為:學號,姓名,年齡,C語言成績,英語成績,數據庫成績\n");
scanf("%d %s %d %f %f %f",&id,name,&age,&c_score,&english_score,&database_score);
printf("學生信息校對:學號:%d,姓名:%s,年齡:%d,C語言成績:%f,英語成績:%f,數據庫成績:%f\n",id,name,age,c_score,english_score,database_score);
//學生信息加入結構體數組
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++;
//是否繼續錄入信息
printf("是否繼續錄入信息?繼續請輸入y,返回主菜單輸入n\n");
char go_on;
scanf("%s",&go_on);
if(go_on=='y')
{
input_info();
}
}
else
{
printf("學生結構體數據已滿,可以刪除一部分學生信息!\n");
}
}
//查詢信息函數
void query_info()
{
printf("當前功能————查詢信息!\n");
printf("請輸入學生的學號\n");
int id=0;
scanf("%d",&id);
//查找輸入id學生的序號
int student_index=search_one_student(id);
if(student_index!=-1)
{
print_one_student(student_array[student_index]);
}
else
{
printf("沒有該學號的學生!\n");
}
//是否繼續查詢信息
printf("是否繼續查詢信息?繼續請輸入y,返回主菜單輸入n\n");
char go_on;
scanf("%s",&go_on);
if(go_on=='y')
query_info();
}
//修改信息函數
void modify_info()
{
printf("當前功能————修改信息!\n");
printf("請輸入學生的學號\n");
int id=0;
scanf("%d",&id);
//查找輸入id學生的序號
int student_index=search_one_student(id);
if(student_index!=-1)
{
modify_one_student(student_index);
}
else
{
printf("沒有該學號的學生!\n");
}
}
//刪除信息函數
void delete_info()
{
printf("當前功能————刪除信息!\n");
printf("請輸入學生的學號\n");
int id=0;
scanf("%d",&id);
//查找輸入id學生的序號
int student_index=search_one_student(id);
if(student_index!=-1)
{
//防止student_index被改變,傳入temp_index計算
int temp_index=student_index;
print_one_student(student_array[temp_index]);
//刪除前進行確認
printf("確定刪除學號 %d 同學的信息?繼續請輸入y\n",id);
char be_true;
scanf("%s",&be_true);
if(be_true=='y')
{
printf("%d\n", student_index);
//執行刪除動作
delete_one_student(student_index);
}
}
else
{
printf("沒有該學號的學生!\n");
}
//是否繼續刪除信息
printf("是否繼續刪除信息?繼續請輸入y,返回主菜單輸入n\n");
char go_on;
scanf("%s",&go_on);
if(go_on=='y')
delete_info();
}
//計算總分函數
void compute_total_score()
{
printf("當前功能————計算總分!\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("總分計算完成!!!\n");
}
//成績排序函數
void sort_info()
{
printf("當前功能————成績排序!\n");
printf("排序前所有學生信息如下:\n");
print_all_students();
int sort_type;
while(1)
{
printf("請輸入排序字段,學號:1,C語言成績:2,英語成績:3,數據庫成績: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("排序後所有學生信息如下:\n");
print_all_students();
//是否繼續刪除信息
printf("是否繼續排序信息?繼續請輸入y,返回主菜單輸入n\n");
char go_on;
scanf("%s",&go_on);
if(go_on=='y')
sort_info();
}
//根據輸入的學號,遍歷結構體數組,若存在該學生,返回數組下標,不存在返回-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;
}
//輸出某個學生的信息
void print_one_student(struct student one)
{
printf("學生信息:學號:%d,姓名:%s,年齡:%d,C語言成績:%f,英語成績:%f,數據庫成績:%f\n",one.id,one.name,one.age,one.c_score,one.english_score,one.database_score);
}
//輸出所有學生的信息
void print_all_students()
{
if(student_count==0)
{
printf("暫無學生信息\n\n\n");
}
for (int i = 0; i < student_count; ++i)
{
print_one_student(student_array[i]);
}
}
void modify_one_student(int student_index)
{
//修改前,輸出學生信息
print_one_student(student_array[student_index]);
//字段序號初始值
int item_index=0;
//不允許修改學號字段
while(1)
{
printf("請輸入要修改的字段序號,姓名:1,年齡:2,C語言成績:3,英語成績:4,數據庫成績: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("修改成功!新的學生信息如下:\n");
//修改後輸出學生信息
print_one_student(student_array[student_index]);
//是否繼續刪除信息
printf("是否繼續修改該學生信息?繼續請輸入y,返回主菜單輸入n\n");
char go_on;
scanf("%s",&go_on);
if(go_on=='y')
modify_one_student(student_index);
}
//刪除數組對應序號的學生信息,把i位置後面的數據組元素向前移動覆蓋i,student_count計數器減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");
}
//根據輸入的字段序號,返回字段名稱
char * get_item_name(int item_index)
{
switch(item_index)
{
case 0:
return "學號";
case 1:
return "姓名";
case 2:
return "年齡";
case 3:
return "C語言成績";
case 4:
return "英語成績";
case 5:
return "數據庫成績";
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("按照 學號 排序完成\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");
}
//按照數據庫成績排序,使用最簡單的冒泡排序法
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("按照 數據庫成績 排序完成\n");
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。