1993-08-02 21:48:44 +04:00
|
|
|
#ifndef lint
|
|
|
|
static char rcsid[] = "$Id: warshall.c,v 1.3 1993/08/02 17:56:52 mycroft Exp $";
|
|
|
|
#endif /* not lint */
|
|
|
|
|
1993-03-21 12:45:37 +03:00
|
|
|
#include "defs.h"
|
|
|
|
|
|
|
|
transitive_closure(R, n)
|
|
|
|
unsigned *R;
|
|
|
|
int n;
|
|
|
|
{
|
|
|
|
register int rowsize;
|
1993-05-28 16:30:03 +04:00
|
|
|
register unsigned i;
|
1993-03-21 12:45:37 +03:00
|
|
|
register unsigned *rowj;
|
|
|
|
register unsigned *rp;
|
|
|
|
register unsigned *rend;
|
|
|
|
register unsigned *ccol;
|
|
|
|
register unsigned *relend;
|
|
|
|
register unsigned *cword;
|
|
|
|
register unsigned *rowi;
|
|
|
|
|
|
|
|
rowsize = WORDSIZE(n);
|
|
|
|
relend = R + n*rowsize;
|
|
|
|
|
|
|
|
cword = R;
|
1993-05-28 16:30:03 +04:00
|
|
|
i = 0;
|
1993-03-21 12:45:37 +03:00
|
|
|
rowi = R;
|
|
|
|
while (rowi < relend)
|
|
|
|
{
|
|
|
|
ccol = cword;
|
|
|
|
rowj = R;
|
|
|
|
|
|
|
|
while (rowj < relend)
|
|
|
|
{
|
1993-05-28 16:30:03 +04:00
|
|
|
if (*ccol & (1 << i))
|
1993-03-21 12:45:37 +03:00
|
|
|
{
|
|
|
|
rp = rowi;
|
|
|
|
rend = rowj + rowsize;
|
|
|
|
while (rowj < rend)
|
|
|
|
*rowj++ |= *rp++;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rowj += rowsize;
|
|
|
|
}
|
|
|
|
|
|
|
|
ccol += rowsize;
|
|
|
|
}
|
|
|
|
|
1993-05-28 16:30:03 +04:00
|
|
|
if (++i >= BITS_PER_WORD)
|
1993-03-21 12:45:37 +03:00
|
|
|
{
|
1993-05-28 16:30:03 +04:00
|
|
|
i = 0;
|
1993-03-21 12:45:37 +03:00
|
|
|
cword++;
|
|
|
|
}
|
|
|
|
|
|
|
|
rowi += rowsize;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
reflexive_transitive_closure(R, n)
|
|
|
|
unsigned *R;
|
|
|
|
int n;
|
|
|
|
{
|
|
|
|
register int rowsize;
|
1993-05-28 16:30:03 +04:00
|
|
|
register unsigned i;
|
1993-03-21 12:45:37 +03:00
|
|
|
register unsigned *rp;
|
|
|
|
register unsigned *relend;
|
|
|
|
|
|
|
|
transitive_closure(R, n);
|
|
|
|
|
|
|
|
rowsize = WORDSIZE(n);
|
|
|
|
relend = R + n*rowsize;
|
|
|
|
|
1993-05-28 16:30:03 +04:00
|
|
|
i = 0;
|
1993-03-21 12:45:37 +03:00
|
|
|
rp = R;
|
|
|
|
while (rp < relend)
|
|
|
|
{
|
1993-05-28 16:30:03 +04:00
|
|
|
*rp |= (1 << i);
|
|
|
|
if (++i >= BITS_PER_WORD)
|
1993-03-21 12:45:37 +03:00
|
|
|
{
|
1993-05-28 16:30:03 +04:00
|
|
|
i = 0;
|
1993-03-21 12:45:37 +03:00
|
|
|
rp++;
|
|
|
|
}
|
|
|
|
|
|
|
|
rp += rowsize;
|
|
|
|
}
|
|
|
|
}
|