【C】C语言实现学生成绩管理系统(EasyX图形界面)

您所在的位置:网站首页 c语言实现成绩排序 【C】C语言实现学生成绩管理系统(EasyX图形界面)

【C】C语言实现学生成绩管理系统(EasyX图形界面)

2023-08-24 07:53| 来源: 网络整理| 查看: 265

输入密码验证——读取文件——验证用户输入是否正确。

显示所有数据——如果通过文件读到了数据会被打印到屏幕上,反之。如果没有读到数据,在添加数据之前都会在屏幕上显示"当前记录为空!"。

各种方式的排序——对当前结构体数组中成员的数据,依照"按xx排序",重新排序,均采用冒泡排序。其中值得注意的是,貌似EasyX的InputBox只能将你输入的内容保存到字符数组中,所以你需要将录入的成绩数据通过atof函数转化为浮点型,这里我采用的方法是: 先按照结构体数组中数据的存储顺序将每个人的某科成绩转化浮点型存储到一个成绩结构体数组中(在写这句话的时候想到,感觉也可以直接将各科的成绩存储到一个结构体数组中,然后在进行比较,可以缩减一下代码量),然后利用冒泡循环对这个存成绩的结构体数组进行重新排序,要注意的是,这个存成绩的结构体数组中元素交换位置的同时,存学生各种数据结构体数组中的元素也要交换位置,这两个的数据的存储顺序是一样的,就是说一个结构体数组辅助另一个结构体数组进行排序,两个结构体需要同时发生变化。

增删查改界面

增——添加数据,以学号区分不同的人,姓名可以相同,但是学号每个是单独的一个,如果输入的学号已经存在,则弹窗提示,进行重新输入,直到输入通过限制条件,通过对输入的学号进行遍历,看看它是不是由纯数字组成,如果不是则弹窗提示输入格式错误,进行重新输入,直到格式正确为止。其中学生姓名不做输入格式限制,成绩同学号。完成全部输入之后进行数据保存,当前结构体人数++。如果添加的时候学号和姓名都是空的则判断为无效输入,操作无效。查——查找数据,(删除数据和修改数据都要依靠查找数据来进行操作,只有先找到结构体里面确实有这个人,才能对他的数据进行操作),通过输入学号或者姓名来查找一个人,在结构体数组中进行遍历来查找,找到则返回该同学在结构体数组对应的下标,然后将该同学的数据输入到屏幕上。反之,弹窗提示"查无此人"。删——删除数据,先进行查找,找到了就弹窗提示是否确认删除,确认删除就利用循环,从要删除的这个人在结构体数组中的下标开始,依次将后面的一个数据覆盖到前面,完成后,结构体数组成员数量--。弹窗提示删除成功。改——修改数据,同样先进行查找,找到了,InputBox提示输入新的数据,注意:与上面录入数据不同的是,这里新输入的学号需要先保存到临时创建的一个字符数组中,不能直接就存到要修改学生在结构体数组中对应的数据位置,因为如果是这样的话,下面在进行判断学号是否已经存在的时候就肯定是存在的了,需要在判断是否重复后,如果数据不重复,再把新输入的学号赋给要修改的变量,还需要注意的是:如果用户输入的新学号和原来的一样是可以的,所以这里需要多加一个判断,否则也会因为检查到数据重复而不能进行下一步。


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3