离散数学中关系的自反、对称、传递闭包C++代码

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
class Relation
{
 int p[20][20];
public:
 Relation()
 {
  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    p[i][j]=0;
 }
 Relation (char *a)
 {
  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    p[i][j]=0;
  for(unsigned int i=0;i<strlen(a);)
  {
  int M,N;//分别用来临时记录关系的前分量和后分量
  if((a[i]>='0' && a[i]<='9') && (a[i+1]>='0' && a[i+1]<='9'))//如果前分量是两位数
  {
   M=(a[i]-'0')*10+a[i+1]-'0';
   i+=3;
   if((a[i]>='0' && a[i]<='9') && (a[i+1]>='0' && a[i+1]<='9'))//如果后分量是两位数
   {
    N=(a[i]-'0')*10+a[i+1]-'0';i+=3;
   }
   else if((a[i]>='0' && a[i]<='9') && (a[i+1]<='0' || a[i+1]>='9'))//如果后分量是一位数
   {
    N=a[i]-'0';i+=2;
   }
  }
  else if((a[i]>='0' && a[i]<='9') && (a[i+1]<='0' || a[i+1]>='9'))//如果前分量是一位数
  {
   M=a[i]-'0';
   i+=2;
   if((a[i]>='0' && a[i]<='9') && (a[i+1]>='0' && a[i+1]<='9'))//如果后分量是两位数
   {
    N=(a[i]-'0')*10+a[i+1]-'0';i+=3;
   }
   else if((a[i]>='0' && a[i]<='9') && (a[i+1]<='0' || a[i+1]>='9'))//如果后分量是一位数
   {
    N=a[i]-'0';i+=2;
   } 
  }
  p[M-1][N-1]=1;//MN有关系
 }
 }
 void composite()
 {
  Relation r1;
  for(int i=0;i<20;i++)
   for (int j=0;j<20;j++)
   {
    for(int k=0;k<20;k++)
     r1.p[i][j]+=p[i][k]*p[k][j];
    if(r1.p[i][j]>0)
     r1.p[i][j]=1;
   }
  r1.output();
 }
 void inverse()
 {
  Relation r2;
  for (int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    r2.p[i][j]=p[j][i];
  r2.output();
 }
 void reflexivity ()
 {
  Relation r;
  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    r.p[i][j]=p[i][j];
  for(int i=0;i<20;i++)
   r.p[i][i]=1;
  r.output();
 }
 void symmetry()
 {
  Relation s;
  for(int i=0;i<20;i++)
   for (int j=0;j<20;j++)
   {
    s.p[i][j]=p[i][j]+p[j][i];
    if(s.p[i][j]>0)
     s.p[i][j]=1;
   }
  s.output();
 }
 void transmit()
 {
  Relation t;
  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    t.p[i][j]=p[i][j];
  for(int k=0;k<20;k++)
   for(int i=0;i<20;i++)
    for(int j=0;j<20;j++)
    {
     t.p[i][j]+=t.p[i][k]*t.p[k][j];
     if(t.p[i][j]>0)
      t.p[i][j]=1;
    }
    t.output();
 }
 void output ()
 {
  for(int i=0;i<20;i++)
  {
   for(int j=0;j<20;j++)
    cout<<p[i][j]<<" ";
   cout<<endl;
  }
 }
 void print()
 {
  int count1=0,count2=1;
  cout<<'{';
  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
    if(p[i][j]==1) count1++;

  for(int i=0;i<20;i++)
   for(int j=0;j<20;j++)
   {
    if(p[i][j]==1 && count2<count1)
    {
     cout<<'<'<<i+1<<','<<j+1<<'>'<<',';
     count2++;
    }
    else if(p[i][j]==1 && count2>=count1)
    {
     cout<<'<'<<i+1<<','<<j+1<<'>';
     count2++;
    }
   }
 
      cout<<'}';
 }

};
int main()
{
 char s[2000];
 cin.getline(s,2000);
 Relation A(s);
 A.output ();
 A.print();
 cout<<endl;
  
    A.inverse();

 A.composite();

 A.reflexivity ();

 A.symmetry();

 A.transmit();
    return 0;
}

  • 5
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值