802. 최종 안전 상태를 찾으십시오 난이도 :
중간 주제 : 깊이 우선 검색, 폭이 넓은 첫 번째 검색, 그래프, 토폴로지 정렬
(또는 다른 안전 노드)로 이어지는 경우. return return 그래프 의 모든 안전 노드
를 포함하는 배열. 대답은오름차순 순서로 정렬되어야합니다 예 1 :
입력 : 그래프 = [[1,2], [2,3], [5], [0], [5], [], []] 출력 : [2,4,5,6] <:> 설명 : 주어진 그래프는 위에 표시되어 있습니다. 노드 5와 6은 그 중 하나의 나가는 가장자리가 없기 때문에 터미널 노드입니다. 노드 2, 4, 5 및 6에서 시작하는 모든 경로는 모두 노드 5 또는 6으로 이어집니다.
예제 2 : 입력 : 그래프 = [[1,2,3,4], [1,2], [3,4], [0,4], []] 출력 :
[4]<:> 설명 : 노드 4만이 터미널 노드이며 노드 4에서 시작하는 모든 경로는 노드 4로 이어집니다. 제약 조건 :
4
세 가지 상태의 방문 배열을 사용합니다.
이 솔루션을 PHP로 구현해 보겠습니다. 802. 최종 안전 상태 찾기
<?php /** * @param Integer[][] $graph * @return Integer[] */ function eventualSafeNodes($graph) { ... ... ... /** * go to ./solution.php */ } /** * DFS helper function * * @param $node * @param $graph * @param $visited * @return int|mixed */ function dfs($node, $graph, &$visited) { ... ... ... /** * go to ./solution.php */ } // Example usage: $graph1 = [[1,2],[2,3],[5],[0],[5],[],[]]; $graph2 = [[1,2,3,4],[1,2],[3,4],[0,4],[]]; print_r(eventualSafeNodes($graph1)) . "\n"; // Output: [2,4,5,6] print_r(eventualSafeNodes($graph2)) . "\n"; // Output: [4] ?>
DFS 기능:
주요 기능:
$graph = [[1,2],[2,3],[5],[0],[5],[],[]]; print_r(eventualSafeNodes($graph));
출력:
[2, 4, 5, 6]
$graph = [[1,2,3,4],[1,2],[3,4],[0,4],[]]; print_r(eventualSafeNodes($graph));
출력:
<?php /** * @param Integer[][] $graph * @return Integer[] */ function eventualSafeNodes($graph) { ... ... ... /** * go to ./solution.php */ } /** * DFS helper function * * @param $node * @param $graph * @param $visited * @return int|mixed */ function dfs($node, $graph, &$visited) { ... ... ... /** * go to ./solution.php */ } // Example usage: $graph1 = [[1,2],[2,3],[5],[0],[5],[],[]]; $graph2 = [[1,2,3,4],[1,2],[3,4],[0,4],[]]; print_r(eventualSafeNodes($graph1)) . "\n"; // Output: [2,4,5,6] print_r(eventualSafeNodes($graph2)) . "\n"; // Output: [4] ?>
github
위 내용은 . 최종 안전 상태를 찾으십시오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!