




已阅读5页,还剩30页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
数据结构课程设计报告设计题目 宿舍管理系统 专 业 信息技术学院 班 级 计算机科学与技术 姓 名 顾文婷 学 号 121114045 完成日期 2014年6月10日 目 录1. 问题描述32. 系统设计3.43. 数据结构与算法描述4-74. 测试结果与分析8-135. 总 结13-146. 参考文献14附录 程序源代码 15-35宿舍管理系统1. 问题描述 建立宿舍管理系统,统计信息包括学生姓名,年龄,出生年月日,性别,学号,班级,系别,床号。2. 系统设计2.1 设计目标宿舍一般由若干学生入驻,每个宿舍都有独立唯一的编号,入住学生也有唯一的学号,另外添加学生的姓名和班级,使用这些关键字就可以方便的查询和管理宿舍入住情况。程序设计应采用交互工作方式,并建立数据文件。程序应通过建立子函数实现创建、保存与载入数据文件,查找、添加、删除、更改、显示等功能,可以自动保存修改。应具有友好的界面和较强的容错能力。能够迅速准确地完成各种学生信息的统计和查询,以方便管理员对学生信息的统一管理。2.2 设计思想为方便管理员对系统进行操作,程序应具有以下功能:(1)创建宿舍数据文件,并提示管理员输入学生姓名、学号、宿舍号、班级等信息,并在本地保存数据文件(2)打开宿舍数据文件:输入文件名打开保存过的数据文件(3)查询住宿信息:提供学号、姓名、宿舍号三种查询方式(4)添加住宿信息:在数据文件中添加新的住宿信息(5)删除住宿信息:提示管理员输入要删除的学生姓名,验证后删除(6)修改住宿信息:提示管理员输入要修改的学生姓名,验证后修改(7)输出数据文件:将住宿信息按学号的大小排序全部输出(8)退出系统2.3 系统模块划分(要给出流程图)3. 数据结构与算法描述 函数原型 函数功能函数处理描述void creat() 初始条件,创建新数据文件,用于存放学生信息调用文件操作函数来实现void readfile() 文件读取函数,打开已有的数据文件调用文件操作函数来实现void output()输出函数,用于输出所有的学生信息调用文件操作函数,并将学号作为关键字进行冒泡排序再输出voidnamesearch()查找函数,用于以姓名为关键字查询使用指针,将关键字与记录比较,若相同则输出void numsearch()查找函数,用于以学号为关键字查询使用指针,将关键字与记录比较,若相同则输出Void dorsearch ()查找函数,用于以房号为关键字查询使用指针,将关键字与记录比较,若相同则输出void add()添加函数,以姓名为关键字加入新的学生信息使用指针,建立一个新节点,将新信息插入原文件中void modify()修改函数,用于以修改已存在的学生信息,以姓名为关键字使用指针,将关键字与记录比较,若相同则更改原纪录并保存在原文件中void deleted()删除函数,用于删除所选的学生信息,以姓名为关键字使用指针,将关键字与记录比较,若相同则删除一切相关记录void main()主函数,用于调用子函数按照输入的命令调用已定义的子函数3.1创建功能(void creat())使用函数新建链表,再使用while循环完成对宿舍数据的录入,包括姓名、学号、班级、宿舍号等信息。最终将录入数据保存在数组里。完成输入后,输入#结束循环。3.2读取功能(void readfile())使用函数读取数据文件,根据输入的文件名加载保存在本地的数据文件,若找不到相同名称文件,则输出错误提示。3.3查找功能 (void namesearch(),void numsearch(),void groupsearch())通过输入选择相关的查询函数来完成查找功能,使用指针将关键字与记录比较,若相同则输出,若无相同则输出错误提示。3.4修改功能(void Modify())使用函数定义指向结构体变量的指针,检验链表中是否有记录,若有记录,根据要修改的编号查找对应结点修改信息并保存,若没记录,输出错误提示。3.5删除功能(void deleted())使用函数定义指向结构体变量的指针,用指针检验链表中是否有记录,若有记录根据要修改的编号查找要删除的结点并删除记录,若没记录,输出错误提示。3.7输出功能(void output()使用循环语句对已有的宿舍记录进行逐个读取,按学号为关键字进行冒泡排序,经过n-1趟子排序完成,第i趟子排序从第1个数至第n-i个数,若第i个数比后一个数大(则升序,小则降序)则交换两数,排序完后按顺序输出所有记录。4. 测试结果与分析5. 总 结通过这次课程设计,我对数据结构在程序中的应用有了更深刻的了解,增强了程序的编写能力,巩固了专业知识,对程序的模块化观念也又模糊逐渐变的清晰了。在程序的运行与调试过程中出现了很多错误,通过反复地复习课本上的相关知识,不停地修改与调试,我终于完成了这段程序。在调试过程中,我认识到了语言的灵活性与严谨性,同一个功能可以由不同的语句来实现,但编写程序时要特别注意细节方面的问题,因为一个小小的疏忽就能导致整个程序不能运行。当然我也认识到了自己的薄弱之处,如对链表相关知识的欠缺,文件运用的不熟练,在以后的学习中我要集中精力、端正态度,争取把知识学得更扎实、更全面。这次课程设计我做的还不是很完善,因为功能不是很多,如果以后有机会会完善的。学生的信息还不够完整,如学生的宿舍长,系别,一些费用以及学生的成绩等待相关详细信息。在这次课程设计的过程中,我体会到要想开发一个系统软件,不仅需要相当的专业技术知识,还要有严谨缜密的思维能力。只有思想上清晰了,编程才有意义,否则就是白费力气。同时还要善于捕获细小的方面,因为那往往是这个程序的致命因素。这次课程设计培养了我的细心和耐性,更树立了一种科学的态度。6. 参考文献数据结构 严蔚敏c+附录 程序源代码#includestdio.h #includestring.h #includestdlib.h #includeconio.h /*头文件*/ #define MAX 100 typedef struct int year; int month; int day; DATE; typedef struct int num; /*学号*/ char name20; /*姓名*/ /*定义结构体*/ char sex6; /*性别*/ int age; /*年龄*/ DATE birthday; /*出生年月*/ char sushe30; /*宿舍号*/ char classes10; /*班级*/ char zhuanye50; /*专业*/ char chuanghao50; /*床号*/ STUDENTS; /*读取信息*/ int read_file(STUDENTS students) FILE *fp; int i=0; if(fp=fopen(stu.txt,rt)=NULL) printf(nn*库存文件不存在!请创建); /*创建文件*/ return 0; while(fread(&studentsi,sizeof(STUDENTS),1,fp)=1) /*成功创建*/ i+; fclose(fp); return i; /*保存信息*/ void save_file(STUDENTS students,int sum) FILE *fp; int i; if(fp=fopen(stu.txt,wb)=NULL) printf(读文件错误!n); return; for(i=0;isum;i+) if(fwrite(&studentsi,sizeof(STUDENTS),1,fp)!=1) printf(写文件错误!n); /*学生信息保存到文件中*/ fclose(fp); /*输入模块*/ int input(STUDENTS students) int i=0,t; /*定义要输入学生的个数*/ system(cls); printf(nn 录入学生个数(最多%d个),MAX); scanf(%d,&t); printf( -n); do / printf(n 第%d个学生信息,i+1); /*输入学生的基本信息*/ printf(n 第%d个学生的学号,i+1); scanf(%d,&studentsi.num); if(studentsi.num=0) break; printf(n 学生姓名:); scanf(%s,); printf(n 学生性别:); scanf(%s,studentsi.sex); printf(n 学生年龄:); scanf(%d,&studentsi.age); printf(n 学生出生年月日:); scanf(%d %d %d,&studentsi.birthday.year,&studentsi.birthday.month, &studentsi.birthday.day); printf(n 学生宿舍:); scanf(%s,studentsi.sushe); printf(n 学生班级:); scanf(%s,studentsi.classes); printf(n 学生专业:); scanf(%s,studentsi.zhuanye); printf(n 学生床号:); scanf(%s,studentsi.chuanghao); i+; while(it); save_file(students,t); /*保存输入的学生信息*/ printf(n %d个学生信息输入完毕! n,t); getch(); return t; /*返回输入学生的个数值*/ /*输出模块*/ void output(STUDENTS students,int sum) int i; system(cls); printf(num name sex age year-month-day sushe classes zhuanye chuanghaon); printf( n); for(i=0;isum;i+) /*输出学生的信息*/ printf(%5d %5s %5s %5d %5d %5d %5d %5s %5s %5s %5sn, studentsi.num,,studentsi.sex,studentsi.age,studentsi.birthday.year, studentsi.birthday.month,studentsi.birthday.day,studentsi.sushe, studentsi.classes,studentsi.zhuanye,studentsi.chuanghao); printf( n); getch(); save_file(students,sum); /*添加信息模块*/ int append(STUDENTS students,int sum) int i=sum,flag=0; /*从已经输入的学生尾部添加*/ char choice; sum=read_file(students); system(cls); printf(nn 添加学生信息 n); do if(iMAX)/*已经输入的学生个数和要添加的学生个数之和要小于定义的学生个数最大值*/ printf(n 新学生学号:); scanf(%d,&studentsi.num); printf(n 学生姓名:); scanf(%s,); printf(n 学生性别:); /*输入添加学生的基本信息*/ scanf(%s,studentsi.sex); printf(n 学生年龄:); scanf(%d,&studentsi.age); printf(n 学生出生年月日:); scanf(%d %d %d,&studentsi.birthday.year,&studentsi.birthday.month,&studentsi.birthday.day); printf(n 学生宿舍号:); scanf(%s,studentsi.sushe); printf(n 学生班级:); scanf(%s,studentsi.classes); printf(n 学生专业:); scanf(%s,studentsi.zhuanye); printf(n 床号:); scanf(%s,studentsi.chuanghao); i+; printf(n 继续添加吗?(Y/N); choice=getch(); if(choice=Y|choice=y) flag=1; printf(n 继续!n); /*是否要继续添加*/ else flag=0; while(flag=1); printf(n 按任意键返回主菜单!); getch(); save_file(students,i); /*保存添加的学生信息到原文件*/ return i; /*返回文件中学生个数值*/ /*修改信息模块*/ void modify(STUDENTS students,int sum) / FILE *fp; int i,choice,flag,modify_num; sum=read_file(students); /*读文件*/ do system(cls); printf(n 输入要修改的学生学号:); scanf(%d,&modify_num); /*输入要修改的学生学号*/ for(i=0;isum;i+) if(studentsi.num=modify_num) printf(n 学生信息 n); printf(num name sex age year-month-day address sushe zhuanye chuanghaon); printf( n); printf(%5d %5s %5s %5d %5d %5d %5d %5s %5s %5s %5sn, studentsi.num,,studentsi.sex,studentsi.age,studentsi.birthday.year,studentsi.birthday.month, studentsi.birthday.day,studentsi.sushe,studentsi.classes,studentsi.zhuanye,studentsi.chuanghao); printf(n 要修改哪一项?n); printf(n 1.学生学号 n); printf(n 2.学生姓名 n); printf(n 3.学生性别 n); printf(n 4.学生年龄 n); printf(n 5.学生出生年月日 n); printf(n 6.学生宿舍号 n); printf(n 7.学生班级 n); printf(n 8.学生专业 n); printf(n 9.学生床号 n); printf(n 请选择(1-9):); scanf(%d,&choice); switch(choice) case 1:printf(n 输入修改后的学号:); scanf(%d,&studentsi.num); break; case 2:printf(n 输入修改后的姓名:); scanf(%s,); break; case 3:printf(n 输入修改后的性别:); scanf(%s,studentsi.sex); break; /*选择要修改学生的项目*/ case 4:printf(n 输入修改后的年龄:); scanf(%d,&studentsi.age); break; case 5:printf(n 输入修改后的出生年月:); scanf(%d %d %d,&studentsi.birthday.year,&studentsi.birthday.month, &studentsi.birthday.day); break; case 6:printf(n 输入修改后的宿舍号:); scanf(%s,studentsi.sushe); break; case 7:printf(n 输入修改后的班级:); scanf(%s,studentsi.classes); break; case 8:printf(n 输入修改后的专业:); scanf(%s,studentsi.zhuanye); break; case 9:printf(n 输入修改后的床号:); scanf(%s,studentsi.chuanghao); break; printf(n 学生信息表 n); printf(num name sex age year-month-day sushe classes zhuanye chuanghaon); printf( n); printf(%5d %5s %5s %5d %5d %5d %5d %5s %5s %5s %5sn, studentsi.num,,studentsi.sex,studentsi.age,studentsi.birthday.year, studentsi.birthday.month,studentsi.birthday.day,studentsi.sushe, studentsi.classes,studentsi.zhuanye,studentsi.chuanghao); break; /*输出修改后的学生信息*/ if(i=sum) printf(n 该学生不存在!); getch(); printf(nn 继续修改吗?(Y/N); choice=getch(); if(choice=Y|choice=y) flag=1; printf(n 继续!n); /*是否要继续修改*/ else flag=0; while(flag=1); printf(n 按任意键返回主菜单!); getch(); save_file(students,sum); /*保存修改后的信息*/ /*删除信息模块*/ int del(STUDENTS students,int sum) int i,del_num; printf(请输入要删除的学生学号); scanf
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- T/CCPITCSC 088-2022天然软木恒温浴室防滑垫
- T/CCMA 0048-2017二手工程机械评估师
- T/CCIA 0015-2023鱼子蓝釉瓷器
- T/CCAS 019-2021水泥及熟料中重金属ICP-OES检测方法
- T/CAPE 10103-2022混凝土物理力学性能试验仪器设备管理规程
- 北京高压考试题及答案
- css考试题模拟试题及答案
- 高校考试题型及答案
- 教材考试题型及答案
- 华为射频面试题及答案
- 2025届江苏省苏州市八校高三下学期三模联考物理试卷(含解析)
- 分子氧氧化丙烯制环氧丙烷铜基催化剂的制备及性能研究
- 2024-2025学年青岛版(五四学制)小学数学二年级下册(全册)知识点复习要点归纳
- 人教版五下-6.1 同分母分数加减法(教学课件)
- 2025年入团考试必考题目试题及答案
- 商标基础知识试题及答案
- 中小学人工智能通识教育指南(2025年版)
- 职业技术学院装配式建筑工程技术专业人才培养方案(2024版)
- 学校学生食品安全培训课件
- 在线网课学习课堂《人工智能(北理 )》单元测试考核答案
- 6.8相遇问题(课件) 数学四年级下册(共15张PPT)人教版
评论
0/150
提交评论