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
-
0 & lt; = 그래프 [i] [j] & lt; = n -1 그래프 [i]는 엄격하게 증가하는 순서로 정렬됩니다 그래프에는 셀프 루프가 포함될 수 있습니다 그래프의 가장자리 수는 범위 [1, 4 * 10 4 - ].
솔루션 :
우리는 그래프에서 모든 안전 노드를 식별해야합니다. 여기에는 주어진 노드에서 시작하는지 확인하는 것이 포함되며, 모든 경로는 결국 터미널 노드 또는 다른 안전 노드에 도달합니다. 이 솔루션은 깊이 우선 검색 (DFS)을 사용하여 사이클을 감지하고 노드를 안전하거나 안전하지 않은 것으로 분류합니다. 주요 통찰력:
- 터미널 노드: 나가는 에지가 없는 노드는 터미널 노드입니다.
- 안전 노드: 해당 노드에서 시작하여 모든 경로가 결국 터미널 노드나 다른 안전 노드로 연결되면 해당 노드는 안전합니다.
- 주기 감지: 노드가 주기의 일부인 경우 해당 노드에서 시작하는 경로가 터미널 노드로 연결되지 않으므로 안전한 노드가 아닙니다.
접근하다:
- 우리는 DFS를 사용하여 각 노드를 탐색하고 그것이 주기의 일부인지 확인합니다. 순환의 일부이거나 순환으로 이어지는 노드는 안전하지 않은 것으로 표시됩니다.
- 결국 터미널 노드나 다른 안전한 노드로 연결되는 노드는 안전하다고 표시됩니다.
세 가지 상태의 방문 배열을 사용합니다.
- 0: 해당 노드를 아직 방문하지 않았습니다.
- 1: 노드가 현재 방문 중입니다(즉, 재귀 스택에서).
- 2: 노드가 완전히 처리되어 안전합니다.
단계:
- 각 노드에 대해 DFS를 수행합니다.
- 방문한 상태를 사용하여 안전/안전하지 않은 노드를 표시합니다.
- 안전한 노드를 모두 모아보세요.
이 솔루션을 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 기능:
- dfs 함수는 노드에 대해 깊이 우선 검색을 수행하여 노드가 시작되면 "방문"(1)으로 표시하고 모든 이웃이 안전하면 "안전"(2)으로 표시합니다.
- 이웃 노드 중 하나라도 주기(dfs($neighbor) == 1로 표시)로 이어지는 경우 해당 노드는 안전하지 않은 것으로 표시됩니다(1).
- 이웃이 모두 터미널 노드나 안전 노드로 이어지면 안전(2)으로 표시됩니다.
-
주요 기능:
- 모든 노드를 반복하고 DFS를 사용하여 각 노드가 안전한지 여부를 확인합니다.
- 모든 안전 노드는 $safeNodes 배열에 수집되어 반환됩니다.
예제 연습:
예시 1:
$graph = [[1,2],[2,3],[5],[0],[5],[],[]]; print_r(eventualSafeNodes($graph));
- 이 예에서 노드 5와 6은 터미널 노드입니다(나가는 가장자리 없음).
- 4번 노드가 5번 노드로 이어지므로 역시 안전합니다.
- 노드 2가 노드 5로 이어지므로 안전합니다.
- 노드 1과 0은 결국 순환이나 안전하지 않은 노드로 이어지기 때문에 안전하지 않습니다.
출력:
[2, 4, 5, 6]
예 2:
$graph = [[1,2,3,4],[1,2],[3,4],[0,4],[]]; print_r(eventualSafeNodes($graph));
- 이 예에서는 노드 4만 터미널 노드이고, 노드 4에서 시작하는 모든 경로는 노드 4로 연결됩니다.
- 다른 모든 노드는 결국 순환 또는 안전하지 않은 노드로 이어집니다.
출력:
<?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] ?>
시간 및 공간 복잡성 :
- 시간 복잡성 : o (n e) , 여기서 n 는 노드 수이고 e 는 가장자리의 수입니다. 우리는 각 노드를 한 번 방문하고 각 모서리를 한 번 처리합니다. 공간 복잡성 : o (n)
- 방문 된 배열 및 재귀 스택의 경우.
이 솔루션은 DFS를 사용하여 안전한 노드를 효율적으로 결정하여 문제 제약이 충족되도록합니다.
연락처 링크
이 시리즈가 도움이된다면 리포지토리 Github에 별을 주거나 좋아하는 소셜 네트워크에서 게시물을 공유하는 것이 무엇입니까? 당신의 지원은 나에게 큰 의미가 있습니다! 이와 같은 유용한 콘텐츠를 원한다면 언제든지 나를 따르십시오 :
LinkedIn
위 내용은 . 최종 안전 상태를 찾으십시오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

TomakePhPapplicationSfaster, followthesesteps : 1) useopCodeCaching likeOpcachetOrpectipiledScriptBecode.2) MinimizedAtabaseQueriesByUsingQueryCachingandEfficientIndexing.3) leveragephp7 assistorBetterCodeeficiession.4) 구현 전략적 지시

toImprovePhPapplicationSpeed, followthesesteps : 1) enableOpCodeCachingWithApcuTeCeScripteXecutionTime.2) 구현 구현

의존성 주입 (DI)은 명시 적으로 전이적 종속성에 의해 PHP 코드의 테스트 가능성을 크게 향상시킵니다. 1) DI 디퍼 커플 링 클래스 및 특정 구현은 테스트 및 유지 보수를보다 유연하게 만듭니다. 2) 세 가지 유형 중에서, 생성자는 상태를 일관성있게 유지하기 위해 명시 적 표현 의존성을 주입합니다. 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하여 코드 품질 및 개발 효율성을 향상시킵니다.

DatabaseQuesyOptimizationInphPinVolvesVesstoigiestoInsperferferferferformance.1) SelectOnlyNecessaryColumnstoredAtatatransfer.2) useinDexingTeSpeedUpdatarretieval.3) ubstractOrerEresultSoffRequeries.4) UtilizePreDstatements Offeffi

phpisusedforendingemailsduetoitsbuitsbuitsbuit-inmail () functionandsupportivelibraries lifephpmailerandswiftmailer.1) usethemail () functionforbasicemails, butithaslimitations.2) EmployPhpmailerforAdvancedFeatirehtMailsAndAtachments.3))

PHP 성능 병목 현상은 다음 단계를 통해 해결할 수 있습니다. 1) 성능 분석을 위해 Xdebug 또는 Blackfire를 사용하여 문제를 찾으십시오. 2) 데이터베이스 쿼리 최적화 및 APCU와 같은 캐시 사용; 3) Array_Filter와 같은 효율적인 기능을 사용하여 배열 작업을 최적화합니다. 4) 바이트 코드 캐시에 대한 OpCache 구성; 5) HTTP 요청을 줄이고 사진 최적화와 같은 프론트 엔드 최적화; 6) 지속적으로 모니터링하고 성능을 최적화합니다. 이러한 방법을 통해 PHP 응용 프로그램의 성능을 크게 향상시킬 수 있습니다.

종속성 주사 (di) inphpisadesignpattern thatmanages 및 enpleducesclassdelencies, 향상 codemodularity, trestability 및 maintainability .itallowspassingDepporsingDikedAbaseConnectionStoclassesAssparameters, 촉진 이용성.

cachingimprovesphpperferferfermanceStoringResultsOfcomputationSorqueriesforquickRetrieval, retingServerloadandenhancancing responsetimestimes : 1) opcodecaching, opcodecaching, whitescompiledphps scriptsinmorytoskipcompileation; 2) dataCachingUsingmemmc


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음