大家好
我就是如假包换的...陈玲
自从运营了C语言程序设计微信公众号
很多粉丝都给我备注
...奇葩
实在是不敢当
也被人开始叫玲玲姐
我知道
很多人都想看我出境
我本人也有 年多的舞台演讲训练
实话告诉大家 —— 我喜欢出境 不过,既然我们做编程语言公众号的,就要去掉其他因素,我们挖掘文字本身所蕴含的力量。所以,这次分享的表达方式就是 —— 纯文字。 今天的分享,只有一个目的
就是上代码
那么,准备好了
#include<stdio.h>
#include<stdlib.h>
//结构体可以存放的学生信息最大个数,不可变变量
int const MAX_LENGTH=;
//学生信息结构体数组,最多可以存放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=; //函数声明
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()
{
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=;
//输入选择的函数编号值
scanf("%d",&function);
//根据输入的函数编号,执行对应的功能
switch(function){
case -:
exit();
case :
print_all_students();
break;
case :
input_info();
break;
case :
query_info();
break;
case :
modify_info();
break;
case :
delete_info();
break;
case :
compute_total_score();
break;
case :
sort_info();
break;
default:
printf("请输入正确的功能编号!!!\n\n");
break;
}
}
return ;
} //录入信息函数
void input_info()
{
printf("当前功能————录入信息!\n");
//判断是否还有空间
if(student_count<MAX_LENGTH)
{
//声明一些临时变量
int id=; char *name=(char *)malloc();
int age=; float c_score=;
float english_score=;
float database_score=;
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=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
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=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
modify_one_student(student_index);
}
else
{
printf("没有该学号的学生!\n");
}
} //删除信息函数
void delete_info()
{
printf("当前功能————删除信息!\n");
printf("请输入学生的学号\n");
int id=;
scanf("%d",&id);
//查找输入id学生的序号
int student_index=search_one_student(id);
if(student_index!=-)
{
//防止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 = ; 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()
{
printf("请输入排序字段,学号:1,C语言成绩:2,英语成绩:3,数据库成绩:4\n");
scanf("%d",&sort_type);
if(sort_type>=&&sort_type<=)
break;
}
switch(sort_type)
{
case :
sort_by_id();
break;
case :
sort_by_c_score();
break;
case :
sort_by_english_score();
break;
case :
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 = ; i < student_count; ++i)
{
if(student_array[i].id==id)
{
return i;
}
}
return -;
} //输出某个学生的信息
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==)
{
printf("暂无学生信息\n\n\n");
}
for (int i = ; 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=;
//不允许修改学号字段
while()
{
printf("请输入要修改的字段序号,姓名:1,年龄:2,C语言成绩:3,英语成绩:4,数据库成绩:5\n");
scanf("%d",&item_index);
if(item_index>=&&item_index<=)
break;
}
switch(item_index)
{
case :
printf("请输入 %s 字段的新值\n", get_item_name(item_index));
char* item_value_1=(char *)malloc();
;
scanf("%s",item_value_1);
student_array[student_index].name=item_value_1;
break;
case :
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 :
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 :
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 :
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-; ++i)
{
student_array[i]=student_array[i+];
}
student_count--;
printf("删除完成\n\n\n");
} //根据输入的字段序号,返回字段名称
char * get_item_name(int item_index)
{
switch(item_index)
{
case :
return "学号";
case :
return "姓名";
case :
return "年龄";
case :
return "C语言成绩";
case :
return "英语成绩";
case :
return "数据库成绩";
default:
return "";
}
} //按照id排序,使用最简单的冒泡排序法
void sort_by_id()
{
for (int i = ; 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 = ; 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 = ; 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 = ; 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");
} 转发自:微信公众号 xs-cyy

C语言学生管理系统源码分享的更多相关文章

  1. C/C++编程笔记:C语言成绩管理系统!链式结构的管理系统源码分享

    最近很多同学因为学校的要求,需要完成自己的那个C语言课程设计,于是就有很多人私信或者加我私聊我,问的最多的还是<学生成绩管理系统>,其实当你项目写多了你就会发现:其实各类的管理系统都离不开 ...

  2. C/C++编程笔记:C语言开发球球大作战(源码分享),你想试试吗?

    游戏背景 <球球大作战>是Superpop一款自主研du发的免费手机网络游戏. 以玩家间的实时互动PK产生游戏乐趣为设计宗旨,通过简单的规则将玩家操作直接转化为游戏策略,体验智谋碰撞的战斗 ...

  3. 3D语音天气球(源码分享)——在Unity中使用Android语音服务

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 开篇废话: 这个项目准备分四部分介绍: 一:创建可旋转的"3D球":3 ...

  4. 一步一步Asp.Net MVC系列_权限管理总结(附MVC权限管理系统源码)

    在上一节中我们总结了关于权限控制的方式,我们这一节讲解关于权限控制中角色权限的授予处理等等并做本系列的总结. 首先,我们来谈谈权限控制中角色权限的控制,上一节只是针对权限拦截中比较粗的控制,如果我们需 ...

  5. 微信小程序——智能小秘“遥知之”源码分享(语义理解基于olami)

    微信小程序智能生活小秘书开发详解 >>>>>>>>>>>>>>>>>>>>> ...

  6. [DeviceOne开发]-土地销售项目源码分享

    一.简介 这个是一个真实项目开源,虽然不是很花哨,但是中规中矩,小细节处理的也很好,非常值得参考和借鉴.里面的数据都缓存到本地,可以离线运行,但是调整一下代码,马上就可以和服务端完全对接.后续会有详细 ...

  7. Net 通用权限管理系统源码 带数据库设计文档,部署说明文档

    Net 通用权限管理系统源码 带数据库设计文档,部署说明文档 包括数据库设计文档部署安装文档源码数据库文件 下载地址:http://www.mallhd.com/archives/1389

  8. WP8.1&Win10幸运大转盘源码分享

    先AD一下我的群:Win10开发者群:53078485 最近在写一个APP,其中需要一个转盘动画的源码,找了很多但是都没有找到,无奈只好自己来写,写完效果自己还是比较满意的,分享出来,有需要的童鞋可以 ...

  9. 3D语音天气球(源码分享)——完结篇

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 开篇废话: 由于这篇文章是本系列最后一篇,有必要进行简单的回顾和思路整理. 这个程序是由两 ...

随机推荐

  1. 定时器 setInterval(‘function()’, 2000)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. gradle问题 cordova

    cordova升级7.0后,运行 > ionic build android  或者 cordova build android     报出错误 Error: Could not find a ...

  3. iperf点对点网络性能测试工具

    什么是Iperf?Iperf 是一个网络性能测试工具.Iperf可以测试TCP和UDP带宽质量.Iperf可以测量最大TCP带宽,具有多种参数和UDP特性.Iperf可以报告带宽,延迟抖动和数据包丢失 ...

  4. hibernate中多对多的注解配置

    hibernate多对多的注解配置中的自动生成中间表的配置: @Entity@Table(name="test_student")public class Students { @ ...

  5. conductor任务域

    任务域 任务域有助于支持任务开发.这个想法是相同的“任务定义”可以在不同的“域”中实现.域名开发人员控制的任意名称.因此,当工作流程启动时,调用者可以在工作流中的所有任务中指定哪些任务需要在特定域中运 ...

  6. win10磁盘碎片整理

    如果我们想要加快win10系统运行速度的话,就需要定期整理碎片才可以,减少卡顿,提高性能. 一:注意事项 固态硬盘用户千万不要使用‘磁盘碎片整理功能’,因为使用的技术不一样,使用window自带的该功 ...

  7. linux下挂载磁盘操作

      重启服务器,查看是否挂载上去了 CentOS云服务器数据盘分区和格式化 腾迅云: http://wiki.qcloud.com/wiki/CentOS%E4%BA%91%E6%9C%8D%E5%8 ...

  8. cf-Round541-Div2-F(并查集+静态链表)

    题目链接:http://codeforces.com/contest/1131/problem/F 思路: 很容易看出这是一道并查集的题目,因为要输出每个cage中住的鸟的编号,故采用静态链表.用l[ ...

  9. hover

    hover - Bing dictionary US[ˈhɒvə(r)] v.盘旋:徘徊:犹豫:巡弋 网络翱翔:悬停:盘旋于

  10. Android网络类型判断(2g、3g、wifi)

    判断网络类型是wifi,还是3G,还是2G网络,对不同 的网络进行不同的处理,现将判断方法整理给大家,以供参考   说明:下面用到的数据移动2G,联通2G,联通3G,wifi我都已经测试过,暂时手上 ...