用C语言开发小型数据库管理系统

  • 格式:txt
  • 大小:5.64 KB
  • 文档页数:3

综合性程序设计试验

实验名称: 用C语言开发小型数据库管理系统

【目的】

1.利用所学的三种程序基本结构以及数组、指针、结构体、用户自定义函数、文件进行一个中型程序的设计,进一步理解和掌握C语言的语法以及三种基本程序结构的综合应用。

2.通过程序中涉及到的排序、查找、求和等操作加深对算法、程序设计思路、常用程序设计技巧的理解与掌握,逐步培养学生的程序开发能力。

【内容】

设某班有n位同学,每位同学的数据包括以下内容:学号(字符串)、姓名(字符串)、数学成绩(字符串)、程序设计成绩(字符串)。设计程序完成以下五项功能:新建数据档案、添加数据、删除数据、对输入的数据进行排序和查询。

注:

1. 采用模块化程序设计思想对系统进行设计;

2. 学生的数据要求用文件保存;

3. 学生的学号作为关键字段,不能相同,姓名可以相同。

4. 要求使用结构体,链或数组等实现。



【步骤】

1. 画出程序流程图;

2. 编制程序;

3. 调试程序,对调试程序时出现的错误进行分析,思考导致错误的原因;

4. 写出通过调试并修改后的正确程序代码。

5. 提交实验报告(电子文档)

【规范】

一、文件名规定

1. 数据库文件名: students.dat(文本文件)

2. 数学成绩排序文件名:sxcj.dat(文本文件)

3. 程序设计成绩排序名:cxsj.dat(文本文件)

二、宏定义、记录结构和全局变量

#define NULL 0

#define LEN sizof(STD)

typedef struct {

char xh[12]; /*学号*/

char xm[12]; /*姓名*/

char sxcj[5]; /*数学成绩*/

char cxsj[5]; /*程序设计成绩*/

char zf[5]; /*总分*/

struct std *next /*指向下条记录*/

struct std *prev /*指向上条记录*/

}STD;

STD *head=NULL; /*链表头指针,定义为全局变量*/

STD *tail=NULL; /*链表尾指针,定义为全局变量*/

STD *current=NULL; /*链表当前结点指针,定义为全局变量*/

三、自定义函数规范

1.void create(void)

该函数在打开数据库文件并读取记录时动态创建链表,同时初始化表头、表尾,置当前指针指向表头。

2.void add_rcd(STD *sp)

将缓冲区sp添加到链表当前结点后,生成一新记录结点,并置当前指针指向新结点。

3.int find_rcd(char *xh)

从当前结点开始按学号搜索结点,成功返回1,并置当前指针指向该结点,失败返回0,当前指针不移动。

4. void verify_rcd( char *info)

修改当前结点指定字段信息。

5

. void next_rcd(void)

指向当前结点的下一结点,如果当前结点为尾结点,不移动当前结点指针。

6. void prev_rcd(void)

指向当前结点的前一结点,如果当前结点为头结点,不移动当前结点指针。

7. void del_rcd(void)

删除当前结点,使当前指针指向下一结点,如果当前结点为尾结点,重置尾结点,使当前指针指向尾结点。如果当前结点为头结点,重置头结点,使当前指针指向头结点。

8. int save_data(void)

保存结点记录,文件名为students.dat

(在以上的函数操作中,一定要注意头指针、尾指针、当前指针是否改变)

9.STD *put_rcd(void)

提供记录输入界面,将记录输入缓冲区,并返回该缓冲区指针。



[头文件data.h]



#define NULL 0

#define LEN sizof(STD)

typedef struct {

char xh[12]; /*学号*/

char xm[12]; /*姓名*/

char sxcj[5]; /*数学成绩*/

char cxsj[5]; /*程序设计成绩*/

char zf[5]; /*总分*/

struct std *next /*指向下条记录*/

struct std *prev /*指向上条记录*/

}STD;

STD *head=NULL; /*链表头指针,定义为全局变量*/

STD *tail=NULL; /*链表尾指针,定义为全局变量*/

STD *current=NULL; /*链表当前结点指针,定义为全局变量*/

STD *create(void);

void add_rcd(STD *sp);

int find_rcd(char *xh);

void verify_rcd(char *info);

void next_rcd(void);

void prev_rcd(void);

void del_rcd(void);

int save_data(void);

STD *put_rcd(void);



[实验报告的具体格式示范]



[姓名:XXX] [学号:XXXXXXX] [日期:]

[题目X]

1、数据结构:

此部分要求说明用来表示题目中数据的数据结构;

如: int m[MAXNUM];

m数组用来表示一个最多12个人队列;

m[2]:表示第二个人是否在队中,其取值为1表示在队列

中,为0表示已出列,不在队列中;

2、算法描述:

此部分要求写出算法的基本思想以及程序中模块(函数)的划分原则;可选择采用伪代码或流程图的方式来说明各模块(函数)的基本思想和思路。

3、程序清单:

程序清单要求加详细注释;如下例所示:

/*本程序完成1到30的累加求和*/

main()

{int I,sum;/ *I:循环变量;sum:求和结果*/

/*开始求和*/

for(sum=0,I=1;I<=30;I++)

sum+=I;

/*输出结果*/

printf(“SUM=%d\n”,sum);

}

【要求】

1.程序运行时,首先显示主菜单如下:

1.新建数据

2.添加数据

3.删除数据

4.排序

5.查询

6.退出

请输入序

号选择相应操作



用户输入序号后,程序进行相应操作。

2.在主菜单中选择序号4,弹出子菜单选择排序方式,子菜单如下:



1.数学成绩排序

2.程序设计成绩排序

3.总分排序。

4.返回主菜单

请按序号选择相应操作



选择子菜单的序号后,程序能正确运行并在屏幕上显示按要求排序后的相关信息。

3.在主菜单中选择序号5,弹出子菜单选择查询方式,子菜单如下:




1.学号查询

2.姓名查询

3.数学成绩查询

4.程序设计成绩查询

5.总分查询

6.返回主菜单

请按序号选择相应操作

在子菜单中选择序号后,程序按以下方式工作。

(1)学号查询:输入学号后,若该学号存在则显示与其相关的所有信息,否则显示找不到的提示信息;(提示:查询到满足条件的结果后,查询即可结束)

(2)姓名查询:输入姓名后,若该姓名存在则显示与其相关的所有信息,否则显示找不到的提示信息;(提示:使用字符串比较函数进行比较)

(3)按科目查询:输入指定分数,程序运行后显示该科目中考试成绩大于等于指定分数的同学的学号、姓名以及该科成绩并统计满足条件的人数;

(4)总分查询:输入指定分数,程序运行后显示总分成绩大于等于指定分数的同学的学号、姓名以及各科成绩并统计满足条件的人数。


下载文档原格式

  / 3
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。