大家好 我就是如假包换的...陈玲 自从运营了C语言程序设计微信公众号 很多粉丝都给我备注 ...奇葩 实在是不敢当 也被人开始叫玲玲姐 我知道 很多人都想看我出境 我本人也有 1 年多的舞台演讲训练 实话告诉大家 —— 我喜欢出境 不过,既然我们做编程语言公众号的,就要去掉其他因素,我们挖掘文字本身所蕴含的力量。所以,这次分享的表达方式就是 —— 纯文字。 今天的分享,只有一个目的 就是上代码 那么,准备好了 #include #include //结构体可以存放的学生信息最大个数,不可变变量 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 { //声明一些临时变量 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'); } ------------------------------------------------华丽的分割线------------------------------------------- 每天还是坚持着上下班,即使上班什么事情也没做 我的理想就是不上班,还有数不尽的钱! |
|