利用Warshall算法求二元关系的可传递闭包.docx

利用Warshall算法求二元关系的可传递闭包.docx

ID:59061857

大小:203.25 KB

页数:7页

时间:2020-10-29

利用Warshall算法求二元关系的可传递闭包.docx_第1页
利用Warshall算法求二元关系的可传递闭包.docx_第2页
利用Warshall算法求二元关系的可传递闭包.docx_第3页
利用Warshall算法求二元关系的可传递闭包.docx_第4页
利用Warshall算法求二元关系的可传递闭包.docx_第5页
资源描述:

《利用Warshall算法求二元关系的可传递闭包.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、离散数学实验训练学院计算机与信息技术学院指导老师景丽萍学生姓名谢昂学号提交日期2014年5月22日利用Warshall算法求二元关系的可传递闭包学生:谢昂指导老师:景丽萍一、设计方案简介 设计一个程序实现求解关系R的传递闭包二、Warshall算法Warshall在1962年提出了一个求关系的传递闭包的有效算法。其具体过程如下,设在n个元素的有限集上关系R的关系矩阵为M:   (1)置新矩阵A=M;   (2)置k=1;   (3)对所有i如果A[i,k]=1,则对j=1..n执行:                     A[i,j]←A[i,j]∨A[k,j];  

2、 (4)k增1;   (5)如果k≤n,则转到步骤(3),否则停止。所得的矩阵A即为关系R的传递闭包t(R)的关系矩阵。三、需求分析用户要自己计算出二元关系的矩阵形式,输入时要按矩阵输入,从第一排第一个开始输入,直到第一排全部输入(每两个数字之间要输入一个空格),然后按回车转换到下一行,以同样的形式输入该行数字,全部输入完成后按回车。然后会输出一个矩阵就是所求的关系R的传递闭包矩阵。程序可以求任意关系R的传递闭包,但必须按要求输入正确的关系矩阵形式。四、概要设计 在集合X上的二元关系R的传递闭包是包含R的X上的最小的传递关系。R的传递闭包在数字图像处理的图像和视觉基础、

3、图的连通性描述等方面都是基本概念。一般用B表示定义在具有n个元素的集合X上关系R的n×n二值矩阵,则传递闭包的矩阵B*可如下计算:      B* = B + B2 + B3 + ……+ (B)n     式中矩阵运算时所有乘法都用逻辑与代替,所有加法都用逻辑或代替。上式中的操作次序为B,B(B),B(BB),B(BBB),……,所以在运算的每一步我们只需简单地把现有结果乘以B,完成矩阵的n次乘法即可。五、主要实验流程图程序开始输入矩阵的维数输入矩阵各元素的值输入是否正确?计算出可传递闭包关系矩阵打印可传递闭包的关系矩阵结束正确不正确六、实验源代码#include"st

4、dio.h"voidWarshall(intn){inti,j,k;inttemp[100][100];intis_correct=0;flag:while(is_correct==0){fflush(stdin);for(inta=0;a

5、

6、temp[a][b]==1)//判断输入是否合法is_correct=1;else{is_correct=0;printf("矩阵输入错误!请

7、重新输入");gotoflag;}}}}for(i=0;i

8、

9、temp[j][k];}}}}printf("传递闭包关系矩阵t(R):");for(i=0;i

10、canf("%d",&n);Warshall(n);return0;}七、试验结果截图展示八、实验总结Warshall算法给我们提供了一个求二元关系传递闭包的高效方法。综合现代计算机技术,利用Warshall算法我们可轻松的求出一个二元关系的可传递闭包。

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

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

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