Heim Backend-Entwicklung C#.Net-Tutorial So implementieren Sie den KMP-Algorithmus in C#

So implementieren Sie den KMP-Algorithmus in C#

Sep 19, 2023 pm 01:31 PM
字符串匹配 c#programmierung kmp-Algorithmus

So implementieren Sie den KMP-Algorithmus in C#

So implementieren Sie den KMP-Algorithmus in C#

Der KMP-Algorithmus (Knuth-Morris-Pratt) ist ein effizienter String-Matching-Algorithmus, der zum Ermitteln der Position von Musterzeichenfolgen in Textzeichenfolgen verwendet wird. Die Kernidee besteht darin, die abgeglichenen Teilinformationen zu verwenden, um unnötige Vergleiche zu vermeiden.

Der Schlüssel zur Implementierung des KMP-Algorithmus besteht darin, eine teilweise Übereinstimmungstabelle (Partial Match Table) zu erstellen, die auch als nächstes Array bezeichnet wird. Dieses Array zeichnet die Länge der längsten passenden Suffix-Teilzeichenfolge jeder Präfix-Teilzeichenfolge in der Musterzeichenfolge auf.

Im Folgenden sind die spezifischen Schritte und Codebeispiele für die Implementierung des KMP-Algorithmus in C# aufgeführt:

Schritt 1: Erstellen Sie eine teilweise übereinstimmende Tabelle.

  1. Definieren Sie als Nächstes ein ganzzahliges Array mit einer Größe der Länge der Musterzeichenfolge und initialisieren Sie es next[0] = -1 .
  2. Definieren Sie zwei Zeiger i und j mit den Anfangswerten 0 bzw. -1.
  3. Bestimmen Sie, ob i das Ende der Musterzeichenfolge erreicht. Wenn nicht, führen Sie die folgenden Schritte aus:
    a. Wenn j gleich -1 ist oder das aktuelle Zeichen gleich dem Zeichen ist, das dem Zeiger j entspricht, werden i und j dies tun gleichzeitig rückwärts bewegt werden, und next[i ] = j.
    b. Bewegen Sie andernfalls den Zeiger j an die Position von next[j] und fahren Sie mit dem Abgleich fort.
  4. Geben Sie als Nächstes die erstellte Teilübereinstimmungstabelle zurück.

Das Folgende ist der Code für die Implementierung der obigen Schritte:

private int[] BuildNext(string pattern)
{
    int[] next = new int[pattern.Length];
    next[0] = -1;
    int i = 0, j = -1;
    
    while (i < pattern.Length - 1)
    {
        if (j == -1 || pattern[i] == pattern[j])
        {
            i++;
            j++;
            next[i] = j;
        }
        else
        {
            j = next[j];
        }
    }
    
    return next;
}
Nach dem Login kopieren

Schritt 2: Verwenden Sie eine teilweise Übereinstimmungstabelle für den Abgleich.

  1. Definieren Sie zwei Zeiger i und j, die auf die Startpositionen der Textzeichenfolge und des Musters zeigen Zeichenfolge bzw.
  2. Bestimmen Sie, ob i und j das Ende erreicht haben:
    a. Wenn j gleich -1 ist oder das aktuelle Zeichen dem Zeichen entspricht, das dem Zeiger j entspricht, werden i und j verschoben gleichzeitig rückwärts.
    b. Bewegen Sie andernfalls den Zeiger j an die Position von next[j] und fahren Sie mit dem Abgleich fort.
  3. Wenn der Zeiger j auf das Ende der Musterzeichenfolge zeigt, bedeutet dies, dass die Übereinstimmung erfolgreich ist und der Index der Startposition in der Textzeichenfolge zurückgegeben wird.
  4. Wenn die Übereinstimmung fehlschlägt, wird -1 zurückgegeben.

Im Folgenden finden Sie den Code zur Implementierung der obigen Schritte:

private int KMP(string text, string pattern)
{
    int[] next = BuildNext(pattern);
    int i = 0, j = 0;
    
    while (i < text.Length && j < pattern.Length)
    {
        if (j == -1 || text[i] == pattern[j])
        {
            i++;
            j++;
        }
        else
        {
            j = next[j];
        }
    }
    
    if (j == pattern.Length)
    {
        return i - j;
    }
    
    return -1;
}
Nach dem Login kopieren

Durch Aufrufen der KMP-Methode und Übergeben der Textzeichenfolge und Musterzeichenfolge können Sie das übereinstimmende Ergebnis erhalten.

Das Obige sind die Schritte und Codebeispiele zur Implementierung des KMP-Algorithmus in C#. Durch die Verwendung teilweise übereinstimmender Tabellen kann der KMP-Algorithmus die Effizienz des Zeichenfolgenabgleichs effektiv verbessern, insbesondere bei der Verarbeitung großer Textzeichenfolgen und langer Musterzeichenfolgen, und eine bessere Leistung erzielen.

Das obige ist der detaillierte Inhalt vonSo implementieren Sie den KMP-Algorithmus in C#. 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)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
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)

So schreiben Sie einen Algorithmus zur Zeitreihenvorhersage mit C# So schreiben Sie einen Algorithmus zur Zeitreihenvorhersage mit C# Sep 19, 2023 pm 02:33 PM

So schreiben Sie einen Algorithmus für die Zeitreihenprognose mit C#. Die Zeitreihenprognose ist eine Methode zur Vorhersage zukünftiger Datentrends durch die Analyse vergangener Daten. Es hat breite Anwendungsmöglichkeiten in vielen Bereichen wie Finanzen, Vertrieb und Wettervorhersage. In diesem Artikel stellen wir anhand spezifischer Codebeispiele vor, wie man Zeitreihenprognosealgorithmen mit C# schreibt. Datenvorbereitung Bevor Sie Zeitreihenprognosen durchführen, müssen Sie zunächst die Daten vorbereiten. Im Allgemeinen sollten Zeitreihendaten eine ausreichende Länge haben und in chronologischer Reihenfolge angeordnet sein. Sie können es aus der Datenbank beziehen oder

So schreiben Sie Deep-Learning-Algorithmen mit C# So schreiben Sie Deep-Learning-Algorithmen mit C# Sep 19, 2023 am 09:53 AM

So verwenden Sie C# zum Schreiben von Deep-Learning-Algorithmen. Einführung: Mit der rasanten Entwicklung der künstlichen Intelligenz hat die Deep-Learning-Technologie in vielen Bereichen bahnbrechende Ergebnisse erzielt. Um das Schreiben und Anwenden von Deep-Learning-Algorithmen zu implementieren, ist Python derzeit die am häufigsten verwendete Sprache. Für Entwickler, die die Sprache C# bevorzugen, ist es jedoch auch möglich, C# zum Schreiben von Deep-Learning-Algorithmen zu verwenden. In diesem Artikel wird das Schreiben von Deep-Learning-Algorithmen mit C# vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Erstellen Sie ein C#-Projekt, bevor Sie mit dem Schreiben eines Deep-Learning-Algorithmus beginnen

So implementieren Sie einen Greedy-Algorithmus in C# So implementieren Sie einen Greedy-Algorithmus in C# Sep 19, 2023 am 11:48 AM

So implementieren Sie den Greedy-Algorithmus in C# Der Greedy-Algorithmus (Greedy-Algorithmus) ist eine häufig verwendete Methode zur Problemlösung. Er wählt jedes Mal die aktuell optimale Lösung aus, in der Hoffnung, die globale optimale Lösung zu erhalten. In C# können wir Greedy-Algorithmen verwenden, um viele praktische Probleme zu lösen. In diesem Artikel wird die Implementierung des Greedy-Algorithmus in C# vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Grundprinzipien des Greedy-Algorithmus Die Grundidee des Greedy-Algorithmus besteht darin, jedes Mal die aktuell optimale Lösung auszuwählen, unabhängig von den möglichen Auswirkungen nachfolgender Schritte. Diese Art des Denkens

So schreiben Sie einen Breitensuchalgorithmus mit C# So schreiben Sie einen Breitensuchalgorithmus mit C# Sep 19, 2023 am 11:45 AM

So schreiben Sie mit C# einen Breitensuchalgorithmus: Die Breitensuche (BFS) ist ein häufig verwendeter Graphsuchalgorithmus, der zum Durchlaufen eines Graphen oder Baums entsprechend der Breite verwendet wird. In diesem Artikel untersuchen wir, wie man mit C# einen Breitensuchalgorithmus schreibt, und stellen konkrete Codebeispiele bereit. Algorithmusprinzip Das Grundprinzip des Breitensuchalgorithmus besteht darin, vom Startpunkt des Algorithmus aus zu beginnen und den Suchbereich Schicht für Schicht zu erweitern, bis das Ziel gefunden oder der gesamte Graph durchquert wird. Die Implementierung erfolgt normalerweise über Warteschlangen.

So schreiben Sie einen Huffman-Codierungsalgorithmus mit C# So schreiben Sie einen Huffman-Codierungsalgorithmus mit C# Sep 21, 2023 pm 03:14 PM

So schreiben Sie einen Huffman-Codierungsalgorithmus mit C#. Einführung: Der Huffman-Codierungsalgorithmus ist ein verlustfreier Algorithmus, der zur Datenkomprimierung verwendet wird. Während der Datenübertragung oder -speicherung werden Daten effektiv komprimiert, indem kürzere Codes für häufigere Zeichen und längere Codes für weniger häufige Zeichen verwendet werden. In diesem Artikel wird erläutert, wie Sie mit C# den Huffman-Codierungsalgorithmus schreiben, und es werden spezifische Codebeispiele bereitgestellt. Das Grundprinzip des Huffman-Codierungsalgorithmus Die Kernidee des Huffman-Codierungsalgorithmus besteht darin, einen Huffman-Baum zu erstellen. Zunächst wird durch Zählen der Häufigkeit des Auftretens von Zeichen ermittelt

So schreiben Sie einen Clusteranalyse-Algorithmus mit C# So schreiben Sie einen Clusteranalyse-Algorithmus mit C# Sep 19, 2023 pm 02:40 PM

So schreiben Sie einen Clusteranalysealgorithmus mit C# 1. Übersicht Die Clusteranalyse ist eine Datenanalysemethode, die unterschiedliche Datenpunkte voneinander trennt, indem ähnliche Datenpunkte in Clustern gruppiert werden. In den Bereichen maschinelles Lernen und Data Mining wird die Clusteranalyse häufig verwendet, um Klassifikatoren zu erstellen, die Struktur von Daten zu untersuchen und verborgene Muster aufzudecken. In diesem Artikel wird erläutert, wie Sie mit C# einen Clusteranalysealgorithmus schreiben. Wir werden den K-Means-Algorithmus als Beispielalgorithmus verwenden und spezifische Codebeispiele bereitstellen. 2. Einführung in den K-Means-Algorithmus Der K-Means-Algorithmus wird am häufigsten verwendet

So schreiben Sie einen schnellen Sortieralgorithmus mit C# So schreiben Sie einen schnellen Sortieralgorithmus mit C# Sep 19, 2023 pm 03:28 PM

So schreiben Sie mit C# einen Schnellsortieralgorithmus. Der Schnellsortieralgorithmus ist ein effizienter Sortieralgorithmus. Seine Idee besteht darin, das Array durch die Idee des Teilens und Eroberns in kleinere Teilprobleme zu unterteilen und diese dann zu lösen. Probleme rekursiv und schließlich zusammenführen, um die Antwort auf das gesamte Problem zu erhalten. Im Folgenden stellen wir detailliert vor, wie man mit C# einen schnellen Sortieralgorithmus schreibt, und geben relevante Codebeispiele. Algorithmusidee Die Idee der schnellen Sortierung kann in den folgenden drei Schritten zusammengefasst werden: Wählen Sie ein Benchmark-Element aus, normalerweise das erste Element des Arrays;

So schreiben Sie den Minimum-Spanning-Tree-Algorithmus mit C# So schreiben Sie den Minimum-Spanning-Tree-Algorithmus mit C# Sep 19, 2023 pm 01:55 PM

So schreiben Sie mit C# den Minimum-Spanning-Tree-Algorithmus. Der Minimum-Spanning-Tree-Algorithmus ist ein wichtiger Algorithmus der Graphentheorie, der zur Lösung des Konnektivitätsproblems von Graphen verwendet wird. In der Informatik bezeichnet ein minimaler Spannbaum einen Spannbaum eines zusammenhängenden Graphen, bei dem die Summe der Gewichte aller Kanten des Spannbaums am kleinsten ist. In diesem Artikel wird erläutert, wie Sie mit C# den Minimal-Spanning-Tree-Algorithmus schreiben, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir eine Diagrammdatenstruktur definieren, um das Problem darzustellen. In C# können Sie eine Adjazenzmatrix zur Darstellung eines Diagramms verwenden. Eine Adjazenzmatrix ist ein zweidimensionales Array, in dem jedes Element dargestellt wird

See all articles