ホームページ >バックエンド開発 >PHPチュートリアル >有向非巡回グラフ内のノードのすべての祖先
2192年。有向非巡回グラフ内のノードのすべての祖先
中
有向非巡回グラフ (DAG) のノード数を表す正の整数 n が与えられます。ノードには 0 から n - 1 (を含む) までの番号が付けられます。
2D 整数配列のエッジも与えられます。ここで、edges[i] = [fromi, toi] は、一方向があることを示します。グラフ内の fromi から toi までのエッジ。
リストの回答を返します。ここで、answer[i] は、昇順でソートされた、i番目ノードの先祖のリストです。
一連のエッジを介して v に到達できる場合、ノード u は別のノード v の祖先です。
例 1:
例 2:
制約:
解決策:
class Solution { /** * @param Integer $n * @param Integer[][] $edges * @return Integer[][] */ function getAncestors($n, $edges) { $adjacencyList = array_fill(0, $n, []); foreach ($edges as $edge) { $from = $edge[0]; $to = $edge[1]; $adjacencyList[$to][] = $from; } $ancestorsList = []; for ($i = 0; $i < $n; $i++) { $ancestors = []; $visited = []; $this->findChildren($i, $adjacencyList, $visited); for ($node = 0; $node < $n; $node++) { if ($node == $i) continue; if (in_array($node, $visited)) $ancestors[] = $node; } $ancestorsList[] = $ancestors; } return $ancestorsList; } private function findChildren($currentNode, &$adjacencyList, &$visitedNodes) { $visitedNodes[] = $currentNode; foreach ($adjacencyList[$currentNode] as $neighbour) { if (!in_array($neighbour, $visitedNodes)) { $this->findChildren($neighbour, $adjacencyList, $visitedNodes); } } } }連絡先リンク
以上が有向非巡回グラフ内のノードのすべての祖先の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。