802. Finden Sie eventuelle sichere Zustände
Schwierigkeit:Mittel
Themen: Tiefensuche, Breitensuche, Diagramm, Topologische Sortierung
Es gibt einen gerichteten Graphen mit n Knoten, wobei jeder Knoten mit 0 bis n - 1 beschriftet ist. Der Graph wird durch einen 0-indizierten 2D-Integer-Array-Graph dargestellt, wobei graph[i] ein Integer-Array ist von Knoten neben Knoten i, was bedeutet, dass es eine Kante vom Knoten i zu jedem Knoten in Graph[i] gibt.
Ein Knoten ist ein Endknoten, wenn es keine ausgehenden Kanten gibt. Ein Knoten ist ein sicherer Knoten, wenn jeder mögliche Pfad, der von diesem Knoten ausgeht, zu einem Endknoten (oder einem anderen sicheren Knoten) führt.
Gibt ein Array zurück, das alle sicheren Knoten des Diagramms enthält. Die Antwort sollte in aufsteigender Reihenfolge sortiert werden.
Beispiel 1:
- Eingabe: graph = [[1,2],[2,3],[5],[0],[5],[],[]]
- Ausgabe: [2,4,5,6]
- Erklärung: Die angegebene Grafik ist oben dargestellt. Die Knoten 5 und 6 sind Endknoten, da von keinem von ihnen ausgehende Kanten vorhanden sind. Jeder Pfad, der an den Knoten 2, 4, 5 und 6 beginnt, führt entweder zu Knoten 5 oder 6.
Beispiel 2:
- Eingabe: graph = [[1,2,3,4],[1,2],[3,4],[0,4],[]]
- Ausgabe: [4]
- Erklärung:Nur Knoten 4 ist ein Endknoten und jeder Pfad, der bei Knoten 4 beginnt, führt zu Knoten 4.
Einschränkungen:
- n == graph.length
- 1 4
- 0
- 0
- graph[i] ist in streng aufsteigender Reihenfolge sortiert.
- Das Diagramm kann Selbstschleifen enthalten.
- Die Anzahl der Kanten im Diagramm liegt im Bereich [1, 4 * 104].
Lösung:
Wir müssen alle sicheren Knoten im Diagramm identifizieren. Dabei wird überprüft, ob jeder Pfad ausgehend von einem bestimmten Knoten schließlich einen Endknoten oder einen anderen sicheren Knoten erreicht. Die Lösung nutzt Depth-First Search (DFS), um Zyklen zu erkennen und Knoten als sicher oder unsicher zu klassifizieren.
Wichtige Erkenntnisse:
- Endknoten: Ein Knoten ohne ausgehende Kanten ist ein Endknoten.
- Sichere Knoten: Ein Knoten ist sicher, wenn alle Pfade von diesem Knoten aus schließlich zu Endknoten oder anderen sicheren Knoten führen.
- Zykluserkennung: Wenn ein Knoten Teil eines Zyklus ist, ist er kein sicherer Knoten, da von ihm ausgehende Pfade nicht zu Endknoten führen.
Ansatz:
- Wir verwenden DFS, um jeden Knoten zu untersuchen und festzustellen, ob er Teil eines Zyklus ist. Knoten, die Teil von Zyklen sind oder zu Zyklen führen, werden als unsicher markiert.
- Knoten, die schließlich zu Endknoten oder anderen sicheren Knoten führen, werden als sicher markiert.
Wir verwenden ein besuchtes Array mit drei Zuständen:
- 0: Der Knoten wurde noch nicht besucht.
- 1: Der Knoten wird gerade besucht (d. h. im Rekursionsstapel).
- 2: Der Knoten wurde vollständig verarbeitet und ist sicher.
Schritte:
- Führen Sie DFS für jeden Knoten durch.
- Verwenden Sie die besuchten Zustände, um sichere/unsichere Knoten zu markieren.
- Sammeln Sie alle sicheren Knoten.
Lassen Sie uns diese Lösung in PHP implementieren: 802. Finden Sie mögliche sichere Zustände
<?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] ?>
Erläuterung:
-
DFS-Funktion:
- Die DFS-Funktion führt eine Tiefensuche auf dem Knoten durch und markiert ihn als „besuchend“ (1), wenn er startet, und als „sicher“ (2), wenn alle seine Nachbarn sicher sind.
- Wenn einer seiner Nachbarn zu einem Zyklus führt (angezeigt durch dfs($neighbor) == 1), wird der Knoten als unsicher (1) markiert.
- Wenn alle Nachbarn zu Endknoten oder sicheren Knoten führen, wird es als sicher (2) markiert.
-
Hauptfunktion:
- Wir durchlaufen alle Knoten und verwenden DFS, um zu prüfen, ob jeder Knoten sicher ist oder nicht.
- Alle sicheren Knoten werden im Array $safeNodes gesammelt und zurückgegeben.
Beispielhafte Vorgehensweise:
Beispiel 1:
$graph = [[1,2],[2,3],[5],[0],[5],[],[]]; print_r(eventualSafeNodes($graph));
- In diesem Beispiel sind die Knoten 5 und 6 Endknoten (keine ausgehenden Kanten).
- Knoten 4 führt zu Knoten 5, daher ist er auch sicher.
- Knoten 2 führt zu Knoten 5, also ist er sicher.
- Knoten 1 und 0 führen schließlich zu einem Zyklus oder unsicheren Knoten, sodass sie nicht sicher sind.
Ausgabe:
[2, 4, 5, 6]
Beispiel 2:
$graph = [[1,2,3,4],[1,2],[3,4],[0,4],[]]; print_r(eventualSafeNodes($graph));
- In diesem Beispiel ist nur Knoten 4 ein Endknoten und alle Pfade, die von Knoten 4 beginnen, führen zu Knoten 4.
- Alle anderen Knoten führen schließlich zu Zyklen oder unsicheren Knoten.
Ausgabe:
<?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] ?>
Zeit und Raumkomplexität:
- Zeitkomplexität : o (n e) , wobei n die Anzahl der Knoten und e ist die Anzahl der Kanten. Wir besuchen jeden Knoten einmal und verarbeiten jede Kante einmal.
- Raumkomplexität : o (n) Für das besuchte Array- und Rekursionsstapel.
Diese Lösung bestimmt effizient die sicheren Knoten mit DFS und stellt sicher, dass die Problembeschränkungen erfüllt sind.
Kontaktlinks
Wenn Sie diese Serie hilfreich gefunden haben, sollten Sie das repository
einen Stern auf Github geben oder den Beitrag in Ihren bevorzugten sozialen Netzwerken teilen? Ihre Unterstützung würde mir viel bedeuten!Wenn Sie mehr hilfreiche Inhalte wie diesen wünschen, können Sie mir gerne folgen:
- GitHub
Das obige ist der detaillierte Inhalt von. Finden Sie eventuelle sichere Zustände. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

PHP bleibt ein leistungsstarkes und weit verbreitetes Tool in der modernen Programmierung, insbesondere im Bereich der Webentwicklung. 1) PHP ist einfach zu bedienen und nahtlos in Datenbanken integriert und für viele Entwickler die erste Wahl. 2) Es unterstützt die Erzeugung der dynamischen Inhalte und die objektorientierte Programmierung, die für die schnelle Erstellung und Wartung von Websites geeignet sind. 3) Die Leistung von PHP kann verbessert werden, indem Datenbankabfragen zwischengespeichert und optimiert werden, und die umfangreiche Community und sein reiches Ökosystem machen es im heutigen Technologiestack immer noch wichtig.

In PHP werden schwache Referenzen in der WeaPreference -Klasse implementiert und verhindern nicht, dass der Müllsammler Objekte zurückerobern. Schwache Referenzen eignen sich für Szenarien wie Caching -Systeme und Event -Hörer. Es ist zu beachten, dass es das Überleben von Objekten nicht garantieren kann und dass die Müllsammlung möglicherweise verzögert wird.

Mit der \ _ \ _ -Invoke -Methode können Objekte wie Funktionen bezeichnet werden. 1. Definieren Sie die Methode \ _ \ _, damit das Objekt aufgerufen werden kann. 2. Bei Verwendung der Syntax $ OBJ (...) wird PHP die Methode \ _ \ _ aufrufen. 3.. Geeignet für Szenarien wie Protokollierung und Taschenrechner, Verbesserung der Codeflexibilität und Lesbarkeit.

Fasern wurde in Php8.1 eingeführt, wodurch die gleichzeitigen Verarbeitungsfunktionen verbessert wurden. 1) Fasern ist ein leichtes Parallelitätsmodell, das Coroutinen ähnelt. 2) Sie ermöglichen es den Entwicklern, den Ausführungsfluss von Aufgaben manuell zu steuern, und eignen sich zum Umgang mit E/O-intensiven Aufgaben. 3) Die Verwendung von Fasern kann effizientere und reaktionsschnelle Code schreiben.

Die PHP -Community bietet umfangreiche Ressourcen und Unterstützung, um Entwicklern zu helfen, zu wachsen. 1) Zu den Ressourcen gehören offizielle Dokumentation, Tutorials, Blogs und Open -Source -Projekte wie Laravel und Symfony. 2) Die Unterstützung kann durch Stackoverflow-, Reddit- und Slack -Kanäle erhalten werden. 3) Entwicklungstrends können durch Befolgung von RFC gelernt werden. 4) Die Integration in die Community kann durch aktive Teilnahme, Beitrag zum Code und Lernfreigabe erreicht werden.

PHP und Python haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1.PHP eignet sich für die Webentwicklung mit einfacher Syntax und hoher Ausführungseffizienz. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit präziser Syntax und reichhaltigen Bibliotheken.

PHP stirbt nicht, sondern sich ständig anpasst und weiterentwickelt. 1) PHP hat seit 1994 mehreren Versionen für die Version unterzogen, um sich an neue Technologietrends anzupassen. 2) Es wird derzeit in E-Commerce, Content-Management-Systemen und anderen Bereichen häufig verwendet. 3) PHP8 führt den JIT -Compiler und andere Funktionen ein, um die Leistung und Modernisierung zu verbessern. 4) Verwenden Sie Opcache und befolgen Sie die PSR-12-Standards, um die Leistung und die Codequalität zu optimieren.

Die Zukunft von PHP wird erreicht, indem sich an neue Technologietrends angepasst und innovative Funktionen eingeführt werden: 1) Anpassung an Cloud Computing, Containerisierung und Microservice -Architekturen, Unterstützung von Docker und Kubernetes; 2) Einführung von JIT -Compilern und Aufzählungsarten zur Verbesserung der Leistung und der Datenverarbeitungseffizienz; 3) die Leistung kontinuierlich optimieren und Best Practices fördern.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Dreamweaver CS6
Visuelle Webentwicklungstools

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version