问题描述:
设计开发一个基于控制台版本的学生管理系统,该系统支持以下功能:
- 打印数据库中的所有信息
- 录入信息到数据库
- 根据输入关键字,删除数据库中的某个同学的信息
- 清空数据库
- 根据输入关键字,查询数据库中某个同学的信息
- 根据输入关键字,修改数据库中某个同学的信息
- 对学生信息进行排序
系统说明:
- 本系统暂时不用STL库中的vector或者list,而是自己用结构体实现链表
- 本系统暂时不用已经成熟的数据库(sqlite,mysql,sqlsever,oracle等),而是用普通的文本文件来简单模拟数据本地存储
- 本系统为控制台界面,适合刚刚学习C和C++的同学,操作界面不太友好(如果要界面比较好看,可以用win32,MFC或者其他界面库)
- 本系统中的学生信息目前只有学号,姓名,年龄,性别(如果需要其他的信息可以自行完善)
- 本系统中对文件的操作使用的函数是fopen,fscanf,fprintf
- 本系统中链表的头结点不保存真正的数据信息,只是为了可以方便的删除第一个元素(单链表结构如图所示)
参考代码:
student.h文件
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include <io.h>
#include <locale>
#define DATABASE_PATH "D:\\student.txt"
typedef struct student
{
int nGender;//0表示性别位置,1表示男,2表示女
int nStudentId;
int nAge;
char name[50];//人的名字一般不超过50个字符
struct student *pNext;//下一个节点指针
}STUDENT;
STUDENT *head;//头指针
STUDENT *last;//指向最后一个元素,方便插入
int i, g_nRecordCount = 0, nAge, nStudentId, nGender;
char name[50];
FILE *stream;
void UpdateDataBase();//把信息写入数据库
void InitHeadNode();//初始化头结点
void LoadDataBase();//加载数据库的数据
void PrintStudentInfo();//打印学生信息
void TackleUserOperation();//处理用户选择功能菜单
void InputInfoToDatabase();//用户选择录入信息
int IsStudentIdExist(int nStudentId);//判断学号是否已经存在,因为学号是不能重复的
void DeleteStudentInfoByStudentId();//根据学号删除该同学信息
void ClearDataBase();//情况数据库中数据
void SearchStudentInfo();//查询学生信息
void UpdateStudentInfo();//修改学生信息
void MySort();//对学生信息进行排序
void MySwap(STUDENT *p1, STUDENT *p2);//交换两个节点的信息
void MySwap(int *p1, int *p2);//交换两个整数
void MySwap(char *p1, char *p2);//交换两个字符串
void SoftByType(int(*CMP)(STUDENT *p1, STUDENT *p2));//根据不同的类型进行排序
int CmpByStudentIdAscend(STUDENT *p1, STUDENT *p2);//按照学号从小到大排序
int CmpByStudentIdDescend(STUDENT *p1, STUDENT *p2);//按照学号从大到小排序
int CmpByAgeAscend(STUDENT *p1, STUDENT *p2);//按照年龄从小到大排序
int CmpByAgeDescend(STUDENT *p1, STUDENT *p2);//按照年龄从大到小排序
main.cpp文件
#define _CRT_SECURE_NO_WARNINGS
#include "student.h"
void UpdateDataBase()//把信息写入数据库
{
if ((stream = fopen(DATABASE_PATH, "