- 5
- 0
- 约2.01千字
- 约 7页
- 2019-09-29 发布于江苏
- 举报
离散数学实验训练
学 院 计算机与信息技术学院
指导老师 景丽萍
学生姓名 谢昂
学 号
提交日期 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];???(4)k增1;???(5)如果k≤n,则转到步骤(3),否则停止。所得的矩阵A即为关系R的传递闭包t(R)的关系矩阵。三、需求分析
用户要自己计算出二元关系的矩阵形式,输入时要按矩阵输入,从第一排第一个开始输入,直到第一排全部输入(每两个数字之间要输入一个空格),然后按回车转换到下一行,以同样的形式输入该行数字,全部输入完成后按回车。然后会输出一个矩阵就是所求的关系R的传递闭包矩阵。程序可以求任意关系R的传递闭包,但必须按要求输入正确的关系矩阵形式。
四、概要设计?
在集合X上的二元关系R的传递闭包是包含R的X上的最小的传递关系。R的传递闭包在数字图像处理的图像和视觉基础、图的连通性描述等方面都是基本概念。一般用B表示定义在具有n个元素的集合X上关系R的n×n二值矩阵,则传递闭包的矩阵B*可如下计算:?
?????B*?=?B?+?B2?+?B3?+?……+?(B)n?????
式中矩阵运算时所有乘法都用逻辑与代替,所有加法都用逻辑或代替。上式中的操作次序为B,B(B),B(BB),B(BBB),……,所以在运算的每一步我们只需简单地把现有结果乘以B,完成矩阵的n次乘法即可。
五、主要实验流程图
程序开始
程序开始
输入矩阵的维数
输入矩阵各元素的值
输入是否正确?
计算出可传递闭包关系矩阵
打印可传递闭包的关系矩阵
结束
正确
不正确
六、实验源代码
#include stdio.h
void Warshall(int n)
{
int i , j, k;
int temp[100][100];
int is_correct=0;
flag: while(is_correct==0)
{
fflush(stdin);
for(int a=0;an;a++)
{
printf(请输入矩阵第%d行元素:,a+1);
for(int b=0;bn;b++)
{
scanf(%d,temp[a][b]);
if(temp[a][b]==0||temp[a][b]==1) //判断输入是否合法
is_correct=1;
else
{
is_correct=0;
printf(矩阵输入错误!请重新输入\n);
goto flag;
}
}
}
}
for(i=0;in;i++){
for(j=0;jn;j++){
if(temp[j][i]==1)
{
for(k=0;kn;k++)
{
temp[j][k]=temp[i][k]||temp[j][k];
}
}
}
}
printf(传递闭包关系矩阵t(R):\n);
for(i=0;in;i++)
{
for(j=0;jn;j++)
{
printf(%d\t, temp[i][j]);
}
printf(\n);
}
}
int main(int argc, char* argv[])
{
int n;
printf(请输入关系矩阵的维数: );
scanf(%d,n);
Warshall(n);
return 0;
}
七、试验结果截图展示
八、实验总结
Warshall算法给我们提供了一个求二元关系传递闭包的高效方法。综合现代计算机技术,利用Warshall算法我们可轻松的求出一个二元关系的可传递闭包。
您可能关注的文档
- 初赛复习资料.doc
- 初起火灾的扑救与注意事项.doc
- 初高中入团申请书格式范文.doc
- 初高中学情特点.docx
- 判定表测试规范.docx
- 删除的短信如何恢复?安卓手机短信恢复教程.docx
- 判别式与韦达定理.doc
- 判断污水可生化性.docx
- 利勃海尔挖掘机参数.docx
- 利众基金会【2009年度】高等教育奖学金申请表.doc
- 浙江省温州市2024-2025学年七年级上学期语文期末考查卷.docx
- 精品解析:北京市建华实验学校2024-2025学年七年级下学期期中英语试题(原卷版).docx
- 精品解析:北京市通州区2024-2025学年七年级下学期期末考试英语试卷(原卷版).docx
- 精品解析:北京市回民学校2024-2025学年九年级上学期期中语文试题(解析版).docx
- 精品解析:北京市海淀区2025-2026学年九年级上学期期末语文试题(解析版).docx
- 精品解析:北京市东城区汇文中学2025-2026学年八年级上学期期中语文试题(原卷版).docx
- 精品解析:北京市回民学校2024-2025学年九年级上学期期中语文试题(原卷版).docx
- 精品解析:2024-2025学年广东省广州市从化区街口镇中心小学人教版五年级上册期中测试数学试卷(解析版).docx
- 精品解析:北京市通州区2024-2025学年七年级下学期期末考试英语试卷(解析版).docx
- 精品解析:北京市建华实验学校2024-2025学年七年级下学期期中英语试题(解析版).docx
最近下载
- 完整版04融创物业秩序服务可视化标准.ppt
- 统编人教部编版小学语文一年级下册语文标点符号练习+答案 .pdf VIP
- EPS系统参数及整车性能的匹配.pdf VIP
- 湖北省武汉市江岸区2023-2024学年六年级上学期语文期末试卷(含答案)2.docx VIP
- 2025年中国水性粘结剂行业市场全景调研及前景战略研判报告.docx
- EPS系统对车辆操纵稳定性影响的仿真的分析研究.pdf VIP
- 幼儿园年度工作总结卫生保健.pptx
- 职业健康管理:电力行业职业健康课件.pptx VIP
- 2026.01.01施行《招标人主体责任履行指引》PPT课件.pptx VIP
- 湖北省武汉市2022-2023学年六年级上学期语文期末试卷(含答案).pdf VIP
原创力文档

文档评论(0)