Maison >développement back-end >tutoriel php >Comment écrire un algorithme de tri topologique en utilisant PHP
Comment écrire un algorithme de tri topologique en utilisant PHP
Le tri topologique est un algorithme de tri de graphes acycliques dirigés (DAG). Son principe est de trier les nœuds du graphe en fonction de dépendances pour garantir que les directions de toutes les arêtes dans les résultats du tri sont cohérentes. Dans le développement réel, le tri topologique est souvent utilisé pour résoudre des problèmes tels que la planification des tâches et l'analyse des dépendances. Cet article explique comment écrire un algorithme de tri topologique en utilisant PHP, avec des exemples de code.
Idée d'algorithme :
<?php function topologicalSort($graph) { $inDegree = []; // 入度数组 $result = []; // 排序结果 $queue = new SplQueue(); // 队列 // 初始化入度数组 foreach ($graph as $node => $neighbors) { $inDegree[$node] = 0; } // 计算入度数组 foreach ($graph as $node => $neighbors) { foreach ($neighbors as $neighbor) { $inDegree[$neighbor]++; } } // 将入度为0的节点入队 foreach ($inDegree as $node => $degree) { if ($degree == 0) { $queue->enqueue($node); } } // 队列不为空时 while (!$queue->isEmpty()) { $node = $queue->dequeue(); $result[] = $node; // 遍历邻居节点 foreach ($graph[$node] as $neighbor) { $inDegree[$neighbor]--; if ($inDegree[$neighbor] == 0) { $queue->enqueue($neighbor); } } } // 判断是否成功排序 if (count($result) == count($graph)) { return $result; } else { return false; } } // 测试用例 $graph = [ 'A' => ['B', 'C'], 'B' => ['C', 'D'], 'C' => ['E'], 'D' => ['F'], 'E' => [], 'F' => ['G'], 'G' => [] ]; $result = topologicalSort($graph); if ($result) { echo "拓扑排序结果: " . implode(' -> ', $result) . " "; } else { echo "图中存在环,无法进行拓扑排序。 "; } ?>
Cet article présente comment utiliser PHP pour écrire un algorithme de tri topologique et donne des exemples de code correspondants. Le tri topologique est un algorithme pratique souvent utilisé pour résoudre des problèmes tels que la planification des tâches. La maîtrise de l'algorithme de tri topologique contribuera à améliorer les capacités de traitement des graphes acycliques dirigés et à prendre en charge diverses analyses de dépendances au cours du développement. J'espère que cet article vous sera utile. $graph
表示有向图中的节点和它们的邻居节点的关系。我们通过调用topologicalSort
函数来对图进行拓扑排序,返回排序结果或者判断是否存在环。在上述示例中,图中的节点为A、B、C、D、E、F、G,对应的邻居节点关系定义在$graph
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!