- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
51CTO下载-C编写warshall算法的传递闭包
1.利用求传递闭包的Warshall算法,给定关系R,编写求R的可传递闭包的C语言程序并利用下列数据测试。
测试数据为:
0,1,0,0,
0,0,1,0,
0,0,0,1,
0,0,0,0
#include stdio.h
#include stdlib.h
#define N 20
#define M 20
main()
{
int i,j,k,m,n;
int r1[M],r2[M],a[N],mr[N][N]={0};
FILE * fp;
printf(程序自动调用c:/stone2.txt文件内相应数据\n);
fp=fopen(c:\\stone2.txt,r);
fscanf(fp,%d,n); /*读取集合元素个数*/
for(i=0;in;i++) /*读取集合元素*/
fscanf(fp,%d,a[i]);
fscanf(fp,%d,m); /*读取关系个数*/
for(k=0;km;k++)
fscanf(fp,%d,%d,r1[k],r2[k]); /*读取关系*/
fclose(fp);
printf(自反闭包r(R):\n{);
for(i=0;in;i++) printf(%d,%d,,a[i],a[i]); /*输出自反闭包*/
for(k=0;km;k++)
{
if(r1[k]!=r2[k]) printf(%d,%d,,r1[k],r2[k]);
else continue;
}
printf(\b}\n);
printf(对称闭包s(R):\n{); /*输出对称闭包*/
for(k=0;km;k++)
{
if(r1[k]!=r2[k]) printf(%d,%d,%d,%d,,r1[k],r2[k],r2[k],r1[k]);
else printf(%d,%d,,r1[k],r2[k]);
}
printf(\b}\n);
k=0;
for(i=0;in,km;i++)
{
if(r1[k]!=a[i]) continue;
else
{
for(j=0;jn,km;j++) /*关系转换成矩阵*/
{
if(r2[k]!=a[j]) continue;
else
{
mr[i][j]=1;
k++; i=0;j=0;
break;
}
}
}
}
printf(关系所对应的关系矩阵:\n);
for(i=0;in;i++)
{ /*打印关系矩阵*/
for(j=0;jn;j++)
printf(%5d,mr[i][j]);
printf(\n);
}
for(k=0;kn;k++)
for(i=0;in;i++) /*warshall*/
for(j=0;jn;j++)
mr[i][j]+=mr[i][j]+mr[i][k]*mr[k][j];
for(i=0;in;i++)
for(j=0;jn;j++)
{ /*把mr[]非0项赋值为1*/
if(!mr[i][j]) continue;
else mr[i][j]=1;
}
printf(传递闭包对应关系矩阵:\n);
for(i=0;in;i++)
{ /*输出传递闭包对应的关系矩阵*/
for(j=0;jn;j++)
printf(%5d,mr[i][j]);
printf(\n);
}
system(PAUSE);
}
自己写的,三个闭包都有,包括传递闭包,看注释就知道了,还是用文件读写,方便数据输入
文档评论(0)