Transitive ปิดเมทริกซ์ความสามารถในการเข้าถึงเพื่อเข้าถึงจากจุดยอด u ถึงจุดยอด v ของกราฟ ให้กราฟหนึ่งอัน เราต้องหาจุดยอด v ซึ่งสามารถเข้าถึงได้จากจุดยอดอื่น u สำหรับคู่จุดยอดทั้งหมด (u, v)

เมทริกซ์สุดท้ายคือประเภทบูลีน เมื่อมีค่า 1 สำหรับจุดยอด u ถึงจุดยอด v หมายความว่ามีเส้นทางอย่างน้อยหนึ่งเส้นทางจาก u ถึง v
อินพุตและเอาต์พุต
Input: 1 1 0 1 0 1 1 0 0 0 1 1 0 0 0 1 Output: The matrix of transitive closure 1 1 1 1 0 1 1 1 0 0 1 1 0 0 0 1
อัลกอริทึม
transColsure(graph)
ป้อนข้อมูล: กราฟที่ให้มา
ผลลัพธ์: เมทริกซ์การปิดสกรรมกริยา
Begin copy the adjacency matrix into another matrix named transMat for any vertex k in the graph, do for each vertex i in the graph, do for each vertex j in the graph, do transMat[i, j] := transMat[i, j] OR (transMat[i, k]) AND transMat[k, j]) done done done Display the transMat End
<2>ตัวอย่าง
#include<iostream>
#include<vector>
#define NODE 4
using namespace std;
/* int graph[NODE][NODE] = {
{0, 1, 1, 0},
{0, 0, 1, 0},
{1, 0, 0, 1},
{0, 0, 0, 0}
}; */
int graph[NODE][NODE] = {
{1, 1, 0, 1},
{0, 1, 1, 0},
{0, 0, 1, 1},
{0, 0, 0, 1}
};
int result[NODE][NODE];
void transClosure() {
for(int i = 0; i<NODE; i++)
for(int j = 0; j<NODE; j++)
result[i][j] = graph[i][j]; //initially copy the graph to the result matrix
for(int k = 0; k<NODE; k++)
for(int i = 0; i<NODE; i++)
for(int j = 0; j<NODE; j++)
result[i][j] = result[i][j] || (result[i][k] && result[k][j]);
for(int i = 0; i<NODE; i++) { //print the result matrix
for(int j = 0; j<NODE; j++)
cout << result[i][j] << " ";
cout << endl;
}
}
int main() {
transClosure();
} ผลลัพธ์
1 1 1 1 0 1 1 1 0 0 1 1 0 0 0 1