ImageVerifierCode 换一换
格式:DOCX , 页数:56 ,大小:290.54KB ,
资源ID:6406070      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6406070.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构课设报告.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构课设报告.docx

1、数据结构课设报告数据结构课程设计报告题目:简易电子家谱系统的设计与实现姓名: 涂雯 学号:U200814434班级: 0806 专业:计算机科学与技术报告日期: 2010年 9 月 18 日一 问题描述问题背景家谱是记载同一姓氏血缘关系的世系、重要人物、个人事迹、家族历史为主要内容的谱籍,又称“族谱”、“家谱”、“家乘”,还有称作“谱碟”。家谱上可以追本溯源,缅怀先人,下可以辨明关系,联络宗亲,从而启孝梯心,唤德善之本,激励后人,奋发有为,其作用不可尽述。在社会方面,家谱对于海内外华人寻根认祖,增强民族凝聚力起着重要作用。在文史工作者,家谱是研究人口学、社会学、经济学、历史学、氏族学、人物传记

2、,以及研究地方史乃是重要资料。在个人方面家谱又是每个公民身份证明之一。问题内容: 用树形的形式表示某家族的家谱,每个树结点表示一个家族成员,成员基本信息如下,具体属性自行确定。 1、姓名 2、性别 3、出生地 4、配偶 5、电话 6、家庭住址 7、职业 8、简历 9、其他系统实现功能: 1、家谱信息1.1、输入1.2、修改1.3、删除 2、查询2.1、某家谱成员的所有子孙的集合2.2、某家谱成员的所有祖先的集合2.3、某家谱成员的所有同辈成员的集合2.4、求某家谱成员的所有上一辈成员的集合2.5、给出两个家谱成员,确定他们的关系2.6、其他查询 3、统计功能3.1、统计家谱成员的总人数3.2、

3、统计从事某种职业的人数3.3、综合统计其他功能要求:1、用文件保存家谱信息 2、图形方式显示家谱二系统总体设计(模块结构图)程序入口建立家谱读取文件保存家谱添加结点修改结点删除结点输出家谱统计基本查询关系查询祖先列表两人关系三 算法和数据结构的设计由于家族关系本身具有树的特点,所以家族关系在内存的数据结构首选为树。家庭成员之间的关系,用树形结构(家族树)表示,通过左孩子右兄弟的方式变为二叉树,创建的过程实际上就是二叉树的添加结点的过程,根据父亲的名字添加在父亲结点的左边。家谱的创建FamilyTree:FamilyTree() T=NULL;/开始为空家谱 家谱结点的添加void Family

4、Tree:Add(person parent, person addNode) /将addnode添加到parent作为parent的孩子结点 int n=0; addNode-firstchild=addNode-nextsibling=NULL; /初始时firstchild同nextsibling都为空 addNode-parent=parent; if(parent=NULL) /如果父结点空 if(T=NULL) /如果根结点空 addNode-data.Depth=n; T=addNode; /将addnode赋给根结点 return; n=T-data.Depth+1;/否则将原

5、来的根结点成为新根结点的孩子 T-data.Depth=n; /并使原来根结点的depth值加1 addNode-firstchild=T; T-parent=addNode; T=addNode; return; strcpy(addNode-data.parentname,parent-data.name); n=parent-data.Depth+1; addNode-data.Depth=n;/将depth值加1 if(parent-firstchild=NULL) /如果parent无孩子,把addNode加入其firstchild parent-firstchild=addNode

6、; else InsertSibling(parent-firstchild,addNode); /否则插入到相应的兄弟结点中去 家谱结点的修改就是将结点的指针传入,更新数据就可完成,代码如下:void FamilyTree:Modify(person &curnode,person newnode) /修改某个人的信息 strcpy(curnode-data.name,newnode-data.name); strcpy(curnode-data.birthplace,newnode-data.birthplace); strcpy(curnode-data.sex,newnode-data

7、.sex); strcpy(curnode-data.occupation,newnode-data.occupation); strcpy(curnode-data.education,newnode-data.education); strcpy(curnode-data.top_headship,newnode-data.top_headship); curnode-data.height=newnode-data.height; curnode-data.birthdate=newnode-data.birthdate; curnode-data.deathdate=newnode-d

8、ata.deathdate; 家谱结点的删除是删除该结点及这个结点对应的所有孩子结点的信息,释放内存空间就可完成,代码如下:void FamilyTree:Delete(person &rootNode) /删除rootnode结点以及他的所有孩子结点 if(rootNode-parent) /rootnode不是根结点 if(rootNode-parent-firstchild=rootNode)/如果rootnode为其父结点的第一个孩子 rootNode-parent-firstchild=rootNode-nextsibling; /将rootnode的nextsibling结点变为r

9、ootnodeparent结点的firstchild结点 else person p=rootNode-parent-firstchild; /否则,找到rootnode在兄弟中的位置 for(;p-nextsibling!=rootNode;p=p-nextsibling) ; p-nextsibling=rootNode-nextsibling; /插入到兄弟中 PostOrderTraverse(rootNode-firstchild,DestroyNode);/调用后序遍历删除rootnode的所有孩子结点 if(rootNode=T) /删除rootnode结点 DestroyNod

10、e(T); else DestroyNode(rootNode); 家谱信息的存储是按先序遍历的方式依次存入硬盘的,读取的时候,将第一个结点的信息对应根结点,后面依次根据父亲的姓名使用插入函数完成家谱的重建,代码如下:void FamilyTree:SaveFamilyTree() /保存二叉树到文件 fstream f(1.dat,ios:binary|ios:out);/以二进制写方式打开文件 if(!f) cerr文件打开失败!firstchild,Visit); PreOrderTraverse(f,T-nextsibling,Visit); 后序遍历:void FamilyTree:

11、PostOrderTraverse(person &T,void (_cdecl *Visit)(person &T) /后序遍历二叉树,并执行visit函数 if(T) PostOrderTraverse(T-firstchild,Visit); PostOrderTraverse(T-nextsibling,Visit); (*Visit)(T); 成员的查找查找部分涉及的查找方法多样,这里用按姓名查找来代表,其他查找使用的算法思想是类似的,使用递归的方法,代码如下:void FamilyTree:FindByName(person& T,person& Tname,char* name)

12、/search the name in info from root T /查找姓名name的人,若在家谱中,用Tname返回,否则Tname为空,Tname初始为空 if(T) if(strcmp(T-data.name,name)=0) /用string库的strcmp()比较两个字符串,若相等,则找到符合条件的 Tname=T; else FindByName(T-firstchild,Tname,name); /对T的firstchild递归搜索 FindByName(T-nextsibling,Tname,name); /对T的nextsibling递归搜索 四 程序测试及结果分析程

13、序在VC里编译连接运行以后,显示主界面如下:选择相应的操作数,以回车键结束。例如 新建家谱时,出现如下界面,按提示输入各种信息。添加成员,类似界面,按照操作提示输入家谱成员信息。载入家谱:显示家谱所有信息:删除彭了及其子孙后的结果如下:删除成功。重新保存家谱并退出:退出后再进入,显示家谱所有成员信息,可以看出文件已经被保存。经过测试,功能都已实现。五 复杂度分析1) NewFamilyTree() O(1)2) FamilyTree() O(1)3) CreateFamilyTree() O(n)4) DestroyNode(person &pnode) O(1)5) DestroyFamil

14、yTree() O(n)6) PostOrderTraverse(person &T,void (_cdecl *Visit)(person &T) O(n)7) PreOrderTraverse(fstream &f,person &T, void (_cdecl *Visit)(fstream &f,person &T) O(n)8) SaveNode(fstream &f, person &pnode) O(1)9) SaveFamilyTree() O(n)10) ReadNode(fstream &f,person &pnode) O(1)11) FindByName(person&

15、 T,person& Tname,char* name) O(n)12) FindByBirthplace(person& T,person& Tname,char* birthplace) O(n)13) FindByBirthday(person& T,person& Tname,Date day1) O(n)14) FindByDeathday(person& T,person& Tname,Date day1) O(n)15) FindBySex(person& T,person& Tname,char *sex) O(n)16) FindByHeight(person& T,pers

16、on& Tname,int h) O(n)17) FindByAddress(person& T,person& Tname,char* address) O(n)18) FindByEducation(person& T,person& Tname,char* edu) O(n)19) FindByOccupation(person& T,person& Tname,char* job) O(n)20) FindByTopHeadship(person& T,person& Tname,char* top) O(n)21) AddOperation() O(1)22) Display(per

17、son info) O(1)23) IsDateValid(Date date) O(1)24) CompareDate(Date date1, Date date2) O(1)25) IsLeapYear(int year) O(1)26) InsertSibling(person& firstchild,person insertsibling) O(1)27) Delete(person &rootNode) O(n)28) Modify(person &curnode,person newnode) O(1)29) DisplayTree(person &T) O(n)30) Add(

18、person parent, person addNode) O(1)31) FindByRelationship(person pnode) O(n)32) Ancestor(person pnode) O(1)33) Relationship(person pnode1,person pnode2) O(n)34) InputData(person &pnode) O(1)35) InputDate(Date &day) O(1)36) Age(person pNode) O(1)37) Height(person pNode) O(1)38) AverageLife(person &T,

19、int &personNums,int &age) O(n)39) AverageHeight(person &T, int &personNums, int &height) O(n)40) MaleFemale(person&T,int &maleNum,int &femaleNum) O(n)41) FamilyNumber(person pnode) O(1)42) TotalFamilyNumber(person &T,int &totalfamily) O(n)43) TotalFamily(person &T,int &total) O(n)44) GetRoot() O(1)六

20、 源程序Gneealogy.h#define max_char_num 100 #define max_array_num 30 /5个include#include #include #include #include #include #include #include #include #include struct Date int year; /年 int month; /月 int day; /日 ; struct Info char namemax_char_num;/姓名 char birthplacemax_char_num;/出生地点 Date birthdate;/结构d

21、ate定义的出生日期 Date deathdate;/结构date定义的死亡日期 char sexmax_char_num;/性别 char wife_or_husbandmax_char_num;/配偶 char phonemax_array_num;/电话 char addressmax_char_num;/家庭住址 char resumemax_char_num;/简历 /其他信息如下 int height;/高度 char occupationmax_char_num;/职业 char educationmax_char_num;/受教育程度 char top_headshipmax_

22、char_num;/最高职位 char parentnamemax_char_num;/父亲姓名,用于添加节点时用 int Depth;/二叉树深度,输出二叉树时用 ; typedef struct CSNode Info data; /个人信息类型结构 CSNode *firstchild,*nextsibling,*parent; /csnode的第一个孩子节点,下一个兄弟节点,双亲节点*person; class FamilyTree public: FamilyTree();/构造函数 FamilyTree();/析构函数 void NewFamilyTree();/建立一个空的家谱树

23、 void CreateFamilyTree();/从磁盘读取文件建立家谱树 void DestroyFamilyTree();/删除家谱树 void SaveFamilyTree(); /保存家谱树 void PreOrderTraverse(fstream &f,person& T ,void (*Visit)(fstream &f,person &T);/先序遍历家谱树,为保存和显示家谱树作准备 void PostOrderTraverse(person& T,void (*Visit)(person& T);/后序遍历家谱树,为删除家谱树作准备 void ReadNode(fstrea

24、m &f,person &pnode); /从二进制文件读取结点信息以供Create FamilyTree()建立家谱树 void FindByRelationship(person pnode); /按照亲属关系查找某人的父母,孩子,兄弟,若查找成功则显示出来 void Modify(person& pNode,person newValue);/修改某个人的信息 int CompareDate(Date date1, Date date2);/ /比较两日期大小,若date1比date2早,返回-1;date1比date2晚,返回1;date1与date2相等,返回0 void FindB

25、yName(person& T,person& Tname,char* name);/查找姓名name的人,若在家谱中,用Tname返回,否则Tname为空,Tname初始为空 void FindByBirthplace(person &T,person& Tname,char* name);/查找出生地name的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindByBirthday(person &T,person& Tname,Date date);/查找出生日期date的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void Find

26、ByDeathday(person& T,person& Tname,Date date);/查找死亡日期date的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindBySex(person& T,person& Tname,char* name);/查找性别name的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindByHeight(person &T,person &Tname,int height);/查找身高height的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindByEducation(person& T,person& Tname,char* name);/查找受教育程度name的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindByOccupation(person& T,person& Tname,char* name);/查找职位name的人,若在家谱中,则显示出来,否则显示出错信息,Tname初始为空 void FindByTopHeadship(person& T,person& Tname,char* name);/查找最高职位name的人,若在家谱中,则显示出来,否则显示出错信息,Tname

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1