离散数学(集合的运算)实验报告

离散数学(集合的运算)实验报告

ID:47536532

大小:107.51 KB

页数:9页

时间:2020-01-13

离散数学(集合的运算)实验报告_第1页
离散数学(集合的运算)实验报告_第2页
离散数学(集合的运算)实验报告_第3页
离散数学(集合的运算)实验报告_第4页
离散数学(集合的运算)实验报告_第5页
资源描述:

《离散数学(集合的运算)实验报告》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、大连民族学院计算机科学与工程学院实验报告实验题目:集合的运算课程名称:离散数学实验类型:□演示性□验证性□操作性□设计性□综合性专业:网络工程班级:网络111班学生姓名:张山学号:2011083123实验日期:2013年12月22日实验地点:I区实验机房实验学时:8小时实验成绩:指导教师签字:年月日老师评语:9实验题目:集合的运算实验原理:1、实验内容与要求:实验内容:本实验求两个集合间的运算,给定两个集合A、B,求集合A与集合B之间的交集、并集、差集、对称差集和笛卡尔乘积。实验要求:对于给定的集合A、B。用C++/C语言设计一个程序(本实验采用C++),该程序能够完成两个集合间的各种运算,

2、可根据需要选择输出某种运算结果,也可一次输出所有运算结果。2、实验算法:实验算法分为如下几步:(1)、设计整体框架该程序采取操作、打印分离(求解和输出分开)的思想。即先设计函数求解各部分运算并将相应结果传入数组(所求集合)中,然后根据需要打印运算结果。(2)、建立一个集合类(Gather)类体包括的数组a、b、c、d、e、f、g分别存储集合A、B以及所求各种运算的集合。接口(实现操作的函数)包括构造函数,菜单显示函数,求解操作函数,打印各种运算结果等函数。(3)、设计类体中的接口构造函数:对对象进行初始化,建立集合A与集合B。菜单显示函数:设计提示选项,给使用者操作提示。操作函数:该函数是程

3、序的主题部分,完成对集合的所有运算的求解过程,并将结果弹入(存入)对应数组(集合)中,用于打印。具体操作如下:91*求交集:根据集合中交集的定义,将数组a、b中元素挨个比较,把共同元素选出来,并存入数组c(交集集合)中,即求得集合A、B的交集。2*求并集:根据集合中并集的定义,先将数组a中元素依次存入数组g(并集集合)中,存储集合A中某元素前,先将其与已存入g中的元素依次比较,若相同则存入下一个元素,否则直接存入g中,直到所有A中元素存储完毕。接着把b中元素依次存入数组g(并集集合)中,存储前将b中每个元素依次与已存入数组g中的集合A的元素比较,若数组g中没有与该元素相同的元素,则将该元素存

4、入g(并集集合)中,否则进行下一次比较,直到所有b中元素比较并存储完毕,即求得A与B的并集。3*求差集:根据集合中差集的定义知,差集分为两部分,A对B的差集(数组d)和B对A的差集(e)。设计求解A对B的差集,将集合A中元素依次与B中元素比较,若B中无元素与该元素相同,则将其存入数组d中(同时删除d中相同的元素,操作方法与求并集时删除相同元素类似),否则进行下一轮比较,直到A中所有元素比较完毕,即求得A对B的差集(数组d)。求解B对A的差集方法与求解A对B的差集类似,这里不再重复。4*求对称差:根据集合中对称差集的定义,将3*中所求两部分差集求并集并存入数组f中即可。操作过程与求并集相似,这

5、里不再重复。5*求笛卡尔乘积:根据集合中笛卡尔乘积集的定义,分为A*B和B*A。先设计A*B是我算法,将a中元素循环依次与b中元素配对即可。求B*A与求A*B类似,这里不再重复。实验步骤:一、分析实验阅读实验指导书和离散数学课本,充分理解整个实验的实验内容及要求,以便对实验进行科学的设计。然后对整个实验进行“解剖”9,即把整个实验系统地分成若干部分,分别针对各个部分进行分析,最后预测程序设计过程中可能遇到的问题及解决方案。二、实验设计基于第一步的实验分析制定实验设计的整体方案,然在计算机上设计整体框架,接着依据最初得到的方案有序的设计该程序的各个分支。最后将分支分别填入主体框架的相应位置,检

6、查设计是否有书写错误。没有则进行调试,有则修改。重复上述过程,直到没有书写错误。三、调试程序对第二步设计的程序进行编译链接,对多组具有代表性的数据进行测试,检查程序是否有逻辑错误和程序漏洞。若无,则进行下一步程序优化,否则,续修改调试,直至没有逻辑错误和漏洞。四、优化程序在前面设计的程序的基础上,查找是否有可以简化程序或是有缺陷的地方,亦或是否有可以添加的功能。有,则进行相应的修改,对整个程序进行优化升级,直至趋于完善。五、处理数据输入:运行结果:9六、对实验进行归纳、总结,撰写实验报告。实验记录:一、集合初始化数据输入:1、第一行输入m2、第二行输入m个整数3、第三行输入n4、第四行输入n

7、个整数输入数据的含义:1、m:集合A的元素个数92、n:集合B的元素个数3、m个整数:集合A中的元素4、n个整数:集合B中的元素二、求解输入:使用者可以根据提示输入I、U、C、D、K、A、P、E。其含义如下:1、I:输出交集2、U:输出并集3、C:输出差集4、D:输出对称差5、K:输出笛卡尔乘积6、A:输出所有集合运算结果7、P:打印集合A和集合B8、E:退出系统一、实验过程中遇到的问题及其解决过程实验过程遇

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。