C语言学生管理系统源码分享
本文实例为大家分享了C语言学生管理系统源码,供大家参考,具体内容如下
#include#include //结构体可以存放的学生信息最大个数,不可变变量 intconstMAX_LENGTH=100; //学生信息结构体数组,最多可以存放100个学生信息 structstudent{ intid;//学号 char*name;//姓名 intage;//年龄 floatc_score;//C语言成绩 floatenglish_score;//英语成绩 floatdatabase_score;//数据库成绩 floattotal_score;//总分 }student_array[MAX_LENGTH]; //学生信息数量 intstudent_count=0; //函数声明 voidprint_all_students(); voidinput_info(); voidquery_info(); voidmodify_info(); voiddelete_info(); voidcompute_total_score(); voidsort_info(); intsearch_one_student(); voidprint_one_student(structstudentone); voiddelete_one_student(intstudent_index); char*get_item_name(intitem_index); voidmodify_one_student(intstudent_index); voidsort_by_id(); voidsort_by_c_score(); voidsort_by_english_score(); voidsort_by_database_score(); //主函数 intmain() { 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"); //函数选择变量 intfunction=0; //输入选择的函数编号值 scanf("%d",&function); //根据输入的函数编号,执行对应的功能 switch(function){ case-1: exit(1); case0: print_all_students(); break; case1: input_info(); break; case2: query_info(); break; case3: modify_info(); break; case4: delete_info(); break; case5: compute_total_score(); break; case6: sort_info(); break; default: printf("请输入正确的功能编号!!!\n\n"); break; } } return0; } //录入信息函数 voidinput_info() { printf("当前功能————录入信息!\n"); //判断是否还有空间 if(student_count =1&&sort_type<=4) break; } switch(sort_type) { case1: sort_by_id(); break; case2: sort_by_c_score(); break; case3: sort_by_english_score(); break; case4: sort_by_database_score(); break; } printf("排序后所有学生信息如下:\n"); print_all_students(); //是否继续删除信息 printf("是否继续排序信息?继续请输入y,返回主菜单输入n\n"); chargo_on; scanf("%s",&go_on); if(go_on=='y') sort_info(); } //根据输入的学号,遍历结构体数组,若存在该学生,返回数组下标,不存在返回-1 intsearch_one_student(intid) { for(inti=0;i =1&&item_index<=5) break; } switch(item_index) { case1: 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; case2: printf("请输入%s字段的新值\n",get_item_name(item_index)); intitem_value_2; scanf("%d",&item_value_2); student_array[student_index].age=item_value_2; break; case3: printf("请输入%s字段的新值\n",get_item_name(item_index)); floatitem_value_3; scanf("%f",&item_value_3); student_array[student_index].c_score=item_value_3; break; case4: printf("请输入%s字段的新值\n",get_item_name(item_index)); floatitem_value_4; scanf("%f",&item_value_4); student_array[student_index].english_score=item_value_4; break; case5: printf("请输入%s字段的新值\n",get_item_name(item_index)); floatitem_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"); chargo_on; scanf("%s",&go_on); if(go_on=='y') modify_one_student(student_index); } //删除数组对应序号的学生信息,把i位置后面的数据组元素向前移动覆盖i,student_count计数器减1 voiddelete_one_student(intstudent_index) { for(inti=student_index;i student_array[j].id) { structstudenttemp=student_array[i]; student_array[i]=student_array[j]; student_array[j]=temp; } } } printf("按照学号排序完成\n"); } //按照C语言成绩排序,使用最简单的冒泡排序法 voidsort_by_c_score() { for(inti=0;i student_array[j].c_score) { structstudenttemp=student_array[i]; student_array[i]=student_array[j]; student_array[j]=temp; } } } printf("按照C语言成绩排序完成\n"); } //按照英语成绩排序,使用最简单的冒泡排序法 voidsort_by_english_score() { for(inti=0;i student_array[j].english_score) { structstudenttemp=student_array[i]; student_array[i]=student_array[j]; student_array[j]=temp; } } } printf("按照英语成绩排序完成\n"); } //按照数据库成绩排序,使用最简单的冒泡排序法 voidsort_by_database_score() { for(inti=0;i student_array[j].database_score) { structstudenttemp=student_array[i]; student_array[i]=student_array[j]; student_array[j]=temp; } } } printf("按照数据库成绩排序完成\n"); }
关于管理系统的更多内容请点击《管理系统专题》进行学习
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。