Inhaltsverzeichnis
Anwendungsmethode
Algorithmus
Beispiel
Ausgabe
Fazit
Heim Backend-Entwicklung C++ Drucken Sie Knoten in einem gerichteten Graphen, die zu keinem Zyklus gehören

Drucken Sie Knoten in einem gerichteten Graphen, die zu keinem Zyklus gehören

Sep 13, 2023 pm 10:25 PM

Drucken Sie Knoten in einem gerichteten Graphen, die zu keinem Zyklus gehören

In Koordinationsdiagrammen ist die Identifizierung von Hubs, die zu keinem Zyklus gehören, für verschiedene Anwendungen von entscheidender Bedeutung. Diese Zentren bilden die Grundlage azyklischer Untergraphen und spielen eine wichtige Rolle beim Verständnis der allgemeinen Graphenstruktur. Durch die Verwendung effizienter Graphenschnittpunktberechnungen wie Profundity First Hunt (DFS) oder Tarjans Berechnung eng verwandter Teile können wir mühelos Hubs bestimmen und drucken, die an keinen Schleifen teilnehmen. Diese Methoden gewährleisten die Charakterisierung von Zentren ohne zirkuläre Zusammenarbeit, liefern wichtige Erkenntnisse für die nicht-zirkulären Teile von Diagrammen und unterstützen verschiedene kritische Denksituationen im Zusammenhang mit Diagrammen.

Anwendungsmethode

  • Tiefensuche (DFS) mit Schleifenerkennung

  • Tarjans stark verbundener Komponentenalgorithmus

Tiefensuche (DFS) mit Schleifenerkennung

Bei diesem Ansatz verwenden wir Depth-First-Tracking (DFS), um im Koordinationsdiagramm zu navigieren und unterwegs Zyklen zu unterscheiden. Wir markieren besuchte Zentren und führen eine Liste, damit die Zentren fortlaufend nach DFS-Methode verfolgt werden können. Wenn wir auf eine Hinterkante stoßen (die Kante der Nabe auf nachhaltige DFS-Weise erreichen), differenzieren wir einen Zyklus. Am Ende der DFS wird das Zentrum im weiteren Verlauf der DFS für einen Zyklus wichtig sein. Hubs, die kein persistentes DFS verwenden, sind nicht Teil einer Schleife und können gedruckt werden.

Algorithmus

  • Starten Sie eine Deep First Hunt (DFS) von jedem nicht besuchten Zentrum auf der Karte.

  • Während der DFS werden besuchte Hubs markiert und zur laufenden DFS-Pfadliste hinzugefügt.

  • Wenn wir auf eine Hinterkante stoßen (die Kante zu einem Hub im aktuellen DFS-Modus), differenzieren wir einen Zyklus und markieren alle Hubs im aktuellen DFS-Modus als Teil des Zyklus.

  • Wenn das DFS des Hubs abgeschlossen ist, entfernen Sie es aus der Liste der in Bearbeitung befindlichen DFS-Pfade.

  • Nach Abschluss der DFS aller Hubs bleiben die Hubs, die keinem Zyklus angehören, unverändert und wir können sie ausdrucken.

Beispiel

#include <iostream>
#include <vector>

class Graph {
public:
   Graph(int numVertices);
   void addEdge(int src, int dest);
   void DFS();
private:
   void DFSUtil(int v, std::vector<bool>& visited, std::vector<int>& dfsPath);
   int numVertices;
   std::vector<std::vector<int>> adjList;
};

Graph::Graph(int numVertices) : numVertices(numVertices) {
   adjList.resize(numVertices);
}

void Graph::addEdge(int src, int dest) {
   adjList[src].push_back(dest);
}

void Graph::DFSUtil(int v, std::vector<bool>& visited, std::vector<int>& dfsPath) {
   visited[v] = true;
   dfsPath.push_back(v);

   for (int neighbor : adjList[v]) {
      if (!visited[neighbor]) {
         DFSUtil(neighbor, visited, dfsPath);
      }
      else {
         std::cout << "Cycle found: ";
         for (size_t i = 0; i < dfsPath.size(); ++i) {
            if (dfsPath[i] == neighbor) {
               while (i < dfsPath.size()) {
                  std::cout << dfsPath[i] << " ";
                  ++i;
               }
               break;
            }
         }
         std::cout << std::endl;
      }
   }

   dfsPath.pop_back();
}

void Graph::DFS() {
   std::vector<bool> visited(numVertices, false);
   std::vector<int> dfsPath;

   for (int i = 0; i < numVertices; ++i) {
      if (!visited[i]) {
         DFSUtil(i, visited, dfsPath);
      }
   }
}

int main() {
   Graph graph(6);
   graph.addEdge(0, 1);
   graph.addEdge(1, 2);
   graph.addEdge(2, 3);
   graph.addEdge(3, 4);
   graph.addEdge(4, 1);
   graph.addEdge(4, 5);
   
   std::cout << "DFS traversal with cycle detection:\n";
   graph.DFS();

   return 0;
}
Nach dem Login kopieren

Ausgabe

DFS traversal with cycle detection:
Cycle found: 1 2 3 4 
Nach dem Login kopieren

Tarjans stark verbundener Komponentenalgorithmus

Tarjans Berechnung ist eine leistungsstarke Berechnung, mit der alle wichtigen relevanten Teile des Koordinationsdiagramms verfolgt werden. Explizit verwandte Teile sind Teilmengen von Hubs, für die eine Koordination zwischen zwei beliebigen Hubs in der Teilmenge besteht. Ein Hub, der nicht Teil einer eng verwandten Komponente ist, ist nicht Teil eines Zyklus. Indem wir wichtige verwandte Teile finden, können wir Naben identifizieren, die zu keinem Zyklus gehören, und diese ausdrucken

Algorithmus

  • Wenden Sie Tarjans Berechnungen auf Ihre Reiseführerkarte an, um den Überblick über alle wichtigen relevanten Teile zu behalten.

  • Unterscheiden Sie nach der Verfolgung aller wichtigen zusammenhängenden Teile die Zentren, die für die eng verwandten Teile entscheidend sind.

  • Hubs, die nicht Teil eines explizit zugeordneten Widgets sind, gehören zu keiner Schleife und können gedruckt werden.

  • Beide Methoden unterscheiden und drucken Zentren, die zu keinem Zyklus im Koordinationsdiagramm gehören. Die DFS-Methode bietet eine einfachere und unkompliziertere Implementierung, während Tarjans Berechnungen komplexer sind, aber zusätzliche Daten zu fokussierten Korrelationsteilen liefern, die für bestimmte diagrammbezogene Aufgaben hilfreich sein können. Die Entscheidung über den Ansatz hängt von den spezifischen Bedürfnissen und dem Kontext der wichtigsten drängenden Probleme ab.

Beispiel

#include <iostream>
#include <vector>
#include <stack>
#include <algorithm>
using namespace std;

class Graph {
   int V;
   vector<vector<int>> adj;
   vector<bool> visited;
   vector<int> disc, low;
   stack<int> st;
   vector<vector<int>> SCCs;
   vector<bool> essentialNodes;

public:
   Graph(int V) : V(V) {
      adj.resize(V);
      visited.resize(V, false);
      disc.resize(V, -1);
      low.resize(V, -1);
      essentialNodes.resize(V, true);
   }

   void addEdge(int u, int v) {
      adj[u].push_back(v);
   }

   void tarjanDFS(int u) {
      static int time = 0;
      disc[u] = low[u] = ++time;
      st.push(u);
      visited[u] = true;

      for (int v : adj[u]) {
         if (disc[v] == -1) {
            tarjanDFS(v);
            low[u] = min(low[u], low[v]);
         } else if (visited[v]) {
            low[u] = min(low[u], disc[v]);
         }
      }

      if (low[u] == disc[u]) {
         vector<int> SCC;
         int v;
         do {
            v = st.top();
            st.pop();
            SCC.push_back(v);
            visited[v] = false;
         } while (v != u);

         SCCs.push_back(SCC);
      }
   }

   void tarjan() {
      for (int i = 0; i < V; ++i) {
         if (disc[i] == -1) {
            tarjanDFS(i);
         }
      }
   }

   void identifyEssentialNodes() {
      for (const vector<int>& SCC : SCCs) {
         for (int v : SCC) {
            for (int u : adj[v]) {
               if (find(SCC.begin(), SCC.end(), u) == SCC.end()) {
                  essentialNodes[u] = false;
               }
            }
         }
      }
   }

   void printEssentialNodes() {
      cout << "Essential Nodes for Each SCC:\n";
      for (int i = 0; i < V; ++i) {
         if (essentialNodes[i]) {
            cout << i << " ";
         }
      }
      cout << endl;
   }
};

int main() {
   Graph g(6);
   g.addEdge(0, 1);
   g.addEdge(1, 2);
   g.addEdge(2, 0);
   g.addEdge(1, 3);
   g.addEdge(3, 4);
   g.addEdge(4, 5);
   g.addEdge(5, 3);

   g.tarjan();
   g.identifyEssentialNodes();
   g.printEssentialNodes();

   return 0;
}
Nach dem Login kopieren

Ausgabe

Essential Nodes for Each SCC:
0 1 2 4 5
Nach dem Login kopieren

Fazit

Diese beiden Methoden lösen das Problem der Identifizierung von Zentren, die zu keinem Zyklus im Koordinationsdiagramm gehören. Die DFS-Methode ist einfach zu implementieren und erfordert nicht viele zusätzliche Informationsstrukturen. Tarjans Berechnungen hingegen liefern zusätzliche Daten zu wichtigen Korrelationsteilen, die in bestimmten Situationen hilfreich sein können.

Die Entscheidung zwischen den beiden Methoden hängt von den spezifischen Voraussetzungen des Problems und den Anforderungen an zusätzliche Daten ab, die periodenunabhängige Differenzierungszentren durchlaufen. Wenn das einzige Ziel im Allgemeinen darin besteht, Hubs zu finden, die zu keinem Zyklus gehören, kann der DFS-Ansatz aufgrund seiner Einfachheit bevorzugt werden. Dennoch können Tarjans Berechnungen ein wichtiges Hilfsmittel sein, wenn eine weitere Untersuchung wichtiger relevanter Teile erforderlich ist. Beide Methoden ermöglichen eine kompetente Gestaltung und können je nach den Eigenschaften des Koordinationsdiagramms und dem gewünschten Ergebnis der Prüfung angepasst werden

Das obige ist der detaillierte Inhalt vonDrucken Sie Knoten in einem gerichteten Graphen, die zu keinem Zyklus gehören. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

C Sprachdatenstruktur: Datenrepräsentation und Betrieb von Bäumen und Grafiken C Sprachdatenstruktur: Datenrepräsentation und Betrieb von Bäumen und Grafiken Apr 04, 2025 am 11:18 AM

C Sprachdatenstruktur: Die Datenrepräsentation des Baumes und des Diagramms ist eine hierarchische Datenstruktur, die aus Knoten besteht. Jeder Knoten enthält ein Datenelement und einen Zeiger auf seine untergeordneten Knoten. Der binäre Baum ist eine besondere Art von Baum. Jeder Knoten hat höchstens zwei Kinderknoten. Die Daten repräsentieren structTreenode {intdata; structTreenode*links; structTreenode*rechts;}; Die Operation erstellt einen Baumtraversalbaum (Vorbereitung, in Ordnung und späterer Reihenfolge) Suchbauminsertion-Knoten Lösches Knotendiagramm ist eine Sammlung von Datenstrukturen, wobei Elemente Scheitelpunkte sind, und sie können durch Kanten mit richtigen oder ungerechten Daten miteinander verbunden werden, die Nachbarn darstellen.

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Mar 12, 2025 pm 04:50 PM

In diesem Artikel werden die C -Standard -Vorlagenbibliothek (STL) erläutert, die sich auf seine Kernkomponenten konzentriert: Container, Iteratoren, Algorithmen und Funktoren. Es wird beschrieben, wie diese interagieren, um die generische Programmierung, die Verbesserung der Codeeffizienz und die Lesbarkeit t zu ermöglichen

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Mar 12, 2025 pm 04:52 PM

Dieser Artikel beschreibt die effiziente Verwendung von STL -Algorithmus in c. Es betont die Auswahl der Datenstruktur (Vektoren vs. Listen), Algorithmus -Komplexitätsanalyse (z. B. std :: sortieren vs. std :: partial_sort), Iteratoranwendungen und parallele Ausführung. Häufige Fallstricke wie

Wie gehe ich effektiv mit Ausnahmen in C um? Wie gehe ich effektiv mit Ausnahmen in C um? Mar 12, 2025 pm 04:56 PM

In diesem Artikel wird die effektive Ausnahmebehandlung in C, Covering Try, Catch und Wurp Mechanics, beschrieben. Es betont Best Practices wie Raii, die Vermeidung unnötiger Fangblöcke und die Protokollierung von Ausnahmen für robusten Code. Der Artikel befasst sich auch mit Perf

Wie verwende ich RValue -Referenzen effektiv in C? Wie verwende ich RValue -Referenzen effektiv in C? Mar 18, 2025 pm 03:29 PM

Artikel erörtert den effektiven Einsatz von RValue -Referenzen in C für Bewegungssemantik, perfekte Weiterleitung und Ressourcenmanagement, wobei Best Practices und Leistungsverbesserungen hervorgehoben werden. (159 Charaktere)

Die Wahrheit hinter dem Problem der C -Sprachdatei Die Wahrheit hinter dem Problem der C -Sprachdatei Apr 04, 2025 am 11:24 AM

Die Wahrheit über Probleme mit der Dateibetrieb: Dateiöffnung fehlgeschlagen: unzureichende Berechtigungen, falsche Pfade und Datei besetzt. Das Schreiben von Daten fehlgeschlagen: Der Puffer ist voll, die Datei ist nicht beschreibbar und der Speicherplatz ist nicht ausreichend. Andere FAQs: Langsame Dateitraversal, falsche Textdateicodierung und Binärdatei -Leser -Fehler.

Wie verwende ich Bereiche in C 20 für ausdrucksstärkere Datenmanipulationen? Wie verwende ich Bereiche in C 20 für ausdrucksstärkere Datenmanipulationen? Mar 17, 2025 pm 12:58 PM

C 20 -Bereiche verbessern die Datenmanipulation mit Ausdruckskraft, Komposition und Effizienz. Sie vereinfachen komplexe Transformationen und integrieren sich in vorhandene Codebasen, um eine bessere Leistung und Wartbarkeit zu erhalten.

Wie funktioniert der dynamische Versand in C und wie wirkt sich dies auf die Leistung aus? Wie funktioniert der dynamische Versand in C und wie wirkt sich dies auf die Leistung aus? Mar 17, 2025 pm 01:08 PM

In dem Artikel wird der dynamische Versand in C, seine Leistungskosten und Optimierungsstrategien erörtert. Es unterstreicht Szenarien, in denen der dynamische Versand die Leistung beeinflusst, und vergleicht sie mit statischer Versand, wobei die Kompromisse zwischen Leistung und Betonung betont werden

See all articles