- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
.
.
编号: 730
数据结构与算法课程设计
说明书
集合的交并差运算
学 院: 海洋信息工程学院
专 业: 网络工程
学生姓名: xx
学 号: xx
指导教师: xx
2017年 12 月 21 日
目录
目录 2
概述 3
程序说明 3
1 HYPERLINK 实验内容 4
1.1 HYPERLINK 实验目的 4
1.2 实验任务 4
1.3 要求 4
2 数据结构设计及流程图 5
2.1 HYPERLINK 抽象数据结构类型定义 5
2.2 HYPERLINK 本程序包含四个模块 7
3 测试数据 8
3.1源程序 8
3.2 测试数据及程序运行情况 14
4 总结 15
参考文献 15
概述
本演示程序的编写,主要运用的我们学的第二章《线性表》中的知识。线性结构的特点是:在数据元素的非空有限集中,(1)存在唯一的一个被称做“第一个”的数据元素;(2)存在唯一的一个被称做“最后一个”的数据元素;(3)除第一个之外,集合中的每个数据元素均只有一个前驱;(4)除最后一个之外,集合中每个数据元素均只有一个后继。
本程序需要两个抽象数据类型:有序表和集合。而且采用了单链表来实现。
一、程序说明
本程序主要利用单链表及函数,实现集合的交集、并集和差集运算。
运行程序说明:
菜单执行的命令包括0-7:
1“请输入A集合的个数与A集合元素”
2“请输入B集合个数与B集合的元素”
3“A集合的有序集合”
4“B集合的有序集合”
5“AB集合的并集”
6“AB集合的交集”
7“AB集合的差集”
0“退出”
注:展示程序中,集合元素限定为小写字母数据,以“回车键”束标志。
实验内容
1.1实验目的:设计一个演示集合的交、并、差的运算程序
1.2实验任务
使用单链表来表示集合,完成集合的交集、并集、差等操作。
采用链表等数据结构。
集合的元素限定为数字和小写的英文字母
1.3实验要求:
初步完成总体设计,建立头文件,确定函数个数。
完成以下条件:
界面清楚,函数功能划分好
总体设计应画流程图
程序要加必要的注释
提供测试方案
注:程序多次测试,弥补漏洞。
要求:
展示程序中,集合元素限定为小写字母数据。集合输入的形式为一以“回车键”束标志。
2)展示程序以用户和计算机的对话方式执行,即在程序输出显示“提示信息”之后,然后再输入命令;相应的输入数据和运算结果显示在其后。
3)程序执行的命令包括0-7:
1“请输入A集合的个数与A集合元素”
2“请输入B集合个数与B集合的元素”
3“A集合的有序集合”
4“B集合的有序集合”
5“AB集合的并集”
6“AB集合的交集”
7“AB集合的差集”
0“退出”
程序功能:计算两个的集合的交、并、差以及重新输入集合功能。
一、数据结构设计及流程图
实现功能:
集合的交 集合的并
为了实现上述程序的功能,应以有序单链表表示集合。为此,需要抽象数据类型:有序表和集合
2.1数据类型定义
1、//线性表的单链表存储结构
typedef struct LNode
{ ElemType data;
struct LNode *next;
} LinkList;
实现输出功能的函数
void DispList()//输出函数
输入n个元素的值,建立带表头结点的单链线性表L
void CreateList_L1(LinkList *L,int n)
4、实现集合元素由小到大排序功能
void sort(LinkList *L)
5、实现了将A、B集合的并集,并放到新的单链表C中
void Union(LinkList *ha,LinkList*hb,LinkList*hc)
6、实现了将A、B集合的交集,并放到新的单链表C中
void InterSect(LinkList *ha,LinkList*hb,LinkList*hc)
7、实现了将A、B集合的差集,并放到新的单链表C中
void Subs(LinkList *ha,LinkList*hb,LinkList*hc)
8、销毁表L
void DestroyList(LinkList *L)
主程序模块()
{
初始化;
定义变量;
While()
{
选择菜单
Switch()
{case1:……case2:……case3:……}
}
Return 0;
}
2.2本程序包含四个模块
1)
原创力文档


文档评论(0)