离散数学实验报告__四个实验!!!
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
《离散数学》
课程设计
学院计算机学院
学生姓名
学号
指导教师
评阅意见
提交日期2011 年11 月25 日
引言
《离散数学》是现代数学的一个重要分支,也是计算机科学与技术,电子信息技术,生物技术等的核心基础课程。它是研究离散量(如整数、有理数、有限字母表等)的数学结构、性质及关系的学问。它一方面充分地描述了计算机科学离散性的特点,为学生进一步学习算法与数据结构、程序设计语言、操作系统、编译原理、电路设计、软件工程与方法学、数据库与信息检索系统、人工智能、网络、计算机图形学等专业课打好数学基础;另一方面,通过学习离散数学课程,学生在获得离散问题建模、离散数学理论、计算机求解方法和技术知识的同时,还可以培养和提高抽象思维能力和严密的逻辑推理能力,为今后爱念族皮及用计算机处理大量的日常事务和科研项目、从事计算机科学和应用打下坚实基础。特别是对于那些从事计算机科学与理论研究的高层次计算机人员来说,离散数学更是必不可少的基础理论工具。
实验一、编程判断一个二元关系的性质(是否具有自反性、反自反性、对称性、反对称性和传递性)
一、前言引语:二元关系是离散数学中重要的内容。因为事物之间总是可以根据需要确定相应的关系。从数学的角度来看,这类联系就是某个集合中元素之间存在的关系。
二、数学原理:自反、对称、传递关系
设A和B都是已知的集合,R是A到B的一个确定的二元关系,那么集合R就是A×B的一个合于R={(x,y)∈A×B|xRy}的子集合
设R是集合A上的二元关系:
自反关系:对任意的x∈A,都满足
对称关系:对任意的x,y∈A,如果
传递关系:对任意的x,y,z∈A,如果
三、实验原理:通过二元关系与关系矩阵的联系,可以引入N维数组,以数组的运算来实现二元关系的判断。
图示:
性质关系矩阵特性
自反性主对角线元素全为1
反自反性主对角线元素全为0
对称性对称矩阵
反对称性非主对角线上的元素等于1且与之对称
的元素等于0
传递性矩阵(M*M)中1所在的位置,M中与
之相对应位置鲜红都为1
四、实验环境:Windows 7 Ultimate DEV C++
五、实验语言:C 语言
六、程序源代码:
#include""
#define N 4
main()
{
int i,j,k;
int f,e,z;
int M[N][N];
printf("判断R是否为自反关系、对称关系、是否可传递\n"); printf("请输入一个4*4的矩阵。\n");
for(i=0;i for(j=0;j scanf("%d",&M[i][j]); for(i=0;i { for(j=0;j printf("%4d",M[i][j]); printf("\n"); } for(i=0;i { if(M[i][i]==1) 序启动画面: ii.输入关系矩阵的行数和列数以及关系矩阵的各个元素。iii.得出结果,并打印在屏幕上。 八、实验总结 如果当一个集合的元素的个数n很大时,求在该集合上的二元关系的可传递闭包是非常复杂的。幸好Warshall算法给我们提供了一个求二元关系的可传递闭包的高效方法。结合计算机程序技术,利用warshall算法我们可以轻松的求出一个二元关系的可传递闭包。本次实验便捷高效地达到了实验的目的。 实验三、编程求一个二元关系的复合运算 一、实验引语:关系作为集合,除了具有一般的运算功能外,还具有自身独特的复合运算。 二、数学原理 设R是集合A到B的二元关系,S是集合B到C的二元关系,则 R。S = {(x,z) A C|(y B)[(x,y) R ∧(y,z)S]}称为R和S 的复合关系。 三、实验原理:矩阵的运算 四、实验环境:Windows 7 Ultimate DEV C++ 五、实验语言:C语言 六、实验程序源代码 #include"" #include"" #define M 3 #define N 3 #define P 3 main() { int i,j,k,x; char p; int A[N][M],B[M][P],C[N][P]; printf("关系的复合运算\n"); printf(“请输入一个3*3的矩阵”); printf("A:\n"); for(i=1;i<=N;i++) { for(j=1;j<=M;j++) scanf("%4d",&A[i][j]); printf("\n"); } printf(“请输入一个3*3的矩阵”);