Heim >Backend-Entwicklung >PHP-Tutorial >String-Matching in einem Array
1408. String-Matching in einem Array
Schwierigkeit:Einfach
Themen:Array, String, String-Matching
Gibt bei einem gegebenen Array von Zeichenfolgenwörtern alle Zeichenfolgen in Wörtern zurück, die eine Teilzeichenfolge eines anderen Wortes sind. Sie können die Antwort in beliebiger Reihenfolge zurücksenden.
Ein Teilstring ist eine zusammenhängende Folge von Zeichen innerhalb eines Strings
Beispiel 1:
Beispiel 2:
Beispiel 3:
Einschränkungen:
Hinweis:
Lösung:
Wir müssen alle Zeichenfolgen im Wortarray finden, die Teilzeichenfolgen eines anderen Wortes im Array sind. Sie können einen Brute-Force-Ansatz verwenden. Der Ansatz besteht darin, jede Zeichenfolge in der Liste zu überprüfen und zu überprüfen, ob es sich um eine Teilzeichenfolge einer anderen Zeichenfolge handelt.
Lassen Sie uns diese Lösung in PHP implementieren: 1408. String-Matching in einem Array
<?php /** * @param String[] $words * @return String[] */ function stringMatching($words) { ... ... ... /** * go to ./solution.php */ } // Example 1 $words = ["mass", "as", "hero", "superhero"]; print_r(stringMatching($words)); // Example 2 $words = ["leetcode", "et", "code"]; print_r(stringMatching($words)); // Example 3 $words = ["blue", "green", "bu"]; print_r(stringMatching($words)); ?> <h3> Erläuterung: </h3> <ol> <li>Die Funktion stringMatching durchläuft alle Wörter im Eingabearray.</li> <li>Für jedes Wort wird es mithilfe einer verschachtelten Schleife mit jedem anderen Wort im Array verglichen.</li> <li>Es verwendet die Funktion strpos() von PHP, um zu überprüfen, ob eine Zeichenfolge eine Teilzeichenfolge einer anderen ist. Die Funktion strpos() gibt false zurück, wenn der Teilstring nicht gefunden wird.</li> <li>Wenn eine Teilzeichenfolge gefunden wird, fügen wir das Wort zum Ergebnisarray hinzu und verlassen die innere Schleife, da wir das Wort nur einmal aufzeichnen müssen.</li> <li>Schließlich gibt die Funktion das Ergebnisarray zurück, das alle Teilzeichenfolgen enthält.</li> </ol> <h3> Zeitkomplexität: </h3> <ul> <li>Die Zeitkomplexität beträgt <em><strong>O(n<sup>2</sup> x m)</strong></em>, wobei <em><strong>n</strong></em> die Anzahl von ist Wörter und <em><strong>m</strong></em> ist die maximale Länge eines Wortes. Dies liegt daran, dass wir für jedes Wort in jedem anderen Wort eine Teilzeichenfolgensuche durchführen.</li> </ul> <h3> Beispielausgaben: </h3> <p>Für die Eingabe ["mass", "as", "hero", "superhero"] lautet die Ausgabe:<br> </p> <pre class="brush:php;toolbar:false">Array ( [0] => as [1] => hero )
Für die Eingabe ["leetcode", "et", "code"] lautet die Ausgabe:
Array ( [0] => et [1] => code )
Für die Eingabe ["blau", "grün", "bu"] lautet die Ausgabe:
Array ( )
Diese Lösung eignet sich gut für die gegebenen Problembeschränkungen.
Kontaktlinks
Wenn Sie diese Serie hilfreich fanden, denken Sie bitte darüber nach, dem Repository einen Stern auf GitHub zu geben oder den Beitrag in Ihren bevorzugten sozialen Netzwerken zu teilen? Ihre Unterstützung würde mir sehr viel bedeuten!
Wenn Sie weitere hilfreiche Inhalte wie diesen wünschen, folgen Sie mir gerne:
Das obige ist der detaillierte Inhalt vonString-Matching in einem Array. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!