suchen
HeimBackend-EntwicklungPHP-TutorialWie generiere ich nicht repetitive Permutationskombinationen basierend auf Charaktersatz und Anzahl der Ebenen und schließen alle Zeichen derselben Kombinationen aus?

Wie generiere ich nicht repetitive Permutationskombinationen basierend auf Charaktersatz und Anzahl der Ebenen und schließen alle Zeichen derselben Kombinationen aus?

Effiziente Erzeugung von Charakteranordnung und Kombination: Vermeiden Sie die Duplikation und schließen Sie dieselbe aus

In diesem Artikel wird beschrieben, wie nicht repetitive Permutationskombinationen auf der Grundlage eines bestimmten Zeichensatzes und der Anzahl der Ebenen erzeugt werden und Kombinationen effektiv ausschließen, bei denen alle Zeichen gleich sind. Zum Beispiel ist der Zeichensatz 'A' und 'B', das eine Kombination verschiedener Schichten erzeugt: Die erste Schicht ist 'A', 'B'; Die zweite Schicht ist 'AB', 'ba' (ohne 'aa', 'bb'); Die dritte Schicht enthält 'Aab', 'Aba', 'Abb', 'Baa', 'Bab', 'BBA' usw.

Wir werden zwei Algorithmus -Strategien anwenden: Methode für digitale Ersatz- und Backtracking -Methode.

Methode 1: Methode für digitale Ersatz (prägnanter)

Diese Methode behandelt Permutationen als M-Digit-Zahlen. Das Annehmen des Charakters 'A', 'B' als Beispiel, 'A' ist 0 und 'B' ist 1. zweiter Schicht Kombination: 00 ('AA'), 01 ('AB'), 10 ('Ba'), 11 ('BB'). Durch alle M-Digit-Zahlen durchlaufen und in Charakterkombinationen umwandeln. Um dieselbe Kombination auszuschließen, wird festgestellt, ob die generierte m-Digit-Zahl durch (11 ... 1) teilbar sein kann (die Anzahl von 1 entspricht der Anzahl der Schichten m).

Beispiel für Python -Code:

 Def generate_combinations (charset, Ebenen, erlauben_all_Same = false):
    Ergebnisse = []
    n = len (charset)
    All_ones = sum (n ** i für i in Bereich (Schichten))
    für i in Reichweite (N ** Schichten):
        Wenn erlaubt_all_Same oder i % All_ones! = 0: #Exclude combination = ""
            temp = i
            für _ im Bereich (Schichten):
                Kombination = charset [temp % n] Kombination
                temp // = n
            results.append (Kombination)
    Rückgabeergebnisse

print (generate_combinations ('ab', 2)) # ['ab', 'ba']
print (generate_combinations ('ab', 2, true)) # ['aa', 'ab', 'ba', 'bb']
print (generate_combinations ('ab', 3)) # ['Aab', 'aba', 'abb', 'baa', 'bab', 'bba']
print (generate_combinations ('abc', 2)) # ['ab', 'ac', 'ba', 'bc', 'ca', 'cb']

Methode 2: Backtracking -Methode (einfacher zu verstehen)

Backtrace ist ein rekursiver Algorithmus, der alle Kombinationen versucht. Fügen Sie der aktuellen Kombination bei jedem Schritt ein Zeichen hinzu und erzeugen rekursiv längere Kombinationen. Verwenden Sie das Flag, um festzustellen, ob die aktuelle Kombination das gleiche Zeichen ist, und vermeiden Sie Duplikation und dieselbe Kombination.

Beispiel für Python -Code:

 Def generate_combinations_recursive (charset, layers, degly_all_Same = false):
    Ergebnisse = []
    current_combination = [''] * Ebenen

    Def Backtrack (Index, All_Same):
        Wenn Index == Schichten:
            Wenn nicht All_Same:
                results.append ("". join (current_combination))
            Zurückkehren
        für char in charset:
            current_combination [index] = char
            Backtrack (Index 1, All_Same und char == current_combination [index - 1] Wenn Index> 0 sonst falsch)

    für char in charset:
        current_combination [0] = char
        Backtrack (1, nicht zulässt_all_Same)

    Rückgabeergebnisse


print (generate_combinations_recursive ('ab', 2)) # ['ab', 'ba']
print (generate_combinations_recursive ('ab', 2, true)) # ['aa', 'ab', 'ba', 'bb']
print (generate_combinations_recursive ('ab', 3)) # ['Aab', 'aba', 'abb', 'baa', 'bab', 'bba']
print (generate_combinations_recursive ('abc', 2)) # ['ab', 'ac', 'ba', 'bc', 'ca', 'cb']

Beide Methoden können das Problem effektiv lösen, und die Auswahl hängt von bestimmten Bedürfnissen und Vorlieben ab. Die digitale Ersatzmethode ist einfacher und die Backtracking -Methode ist einfacher zu verstehen und zu erweitern.

Das obige ist der detaillierte Inhalt vonWie generiere ich nicht repetitive Permutationskombinationen basierend auf Charaktersatz und Anzahl der Ebenen und schließen alle Zeichen derselben Kombinationen aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Wie berechnet man die Gesamtzahl der Elemente in einem multidimensionalen PHP -Array?Wie berechnet man die Gesamtzahl der Elemente in einem multidimensionalen PHP -Array?May 15, 2025 pm 09:00 PM

Die Berechnung der Gesamtzahl der Elemente in einem multidimensionalen PHP -Array kann mit rekursiven oder iterativen Methoden erfolgen. 1. Die rekursive Methode zählt durch Überqueren des Arrays und die rekursive Verarbeitung verschachtelter Arrays. 2. Die iterative Methode verwendet den Stapel, um die Rekursion zu simulieren, um Tiefenprobleme zu vermeiden. 3. Die Funktion array_walk_recursive kann ebenfalls implementiert werden, erfordert jedoch eine manuelle Zählung.

Was sind die Merkmale von Schleifen in PHP?Was sind die Merkmale von Schleifen in PHP?May 15, 2025 pm 08:57 PM

In PHP besteht das Merkmal einer DO-While-Schleife darin, sicherzustellen, dass der Schleifenkörper mindestens einmal ausgeführt wird, und dann zu entscheiden, ob die Schleife basierend auf den Bedingungen fortgesetzt werden soll. 1) Es wird die Schleifenkörper vor der bedingten Überprüfung ausgeführt, die für Szenarien geeignet ist, in denen Vorgänge mindestens einmal ausgeführt werden müssen, z. B. die Überprüfung der Benutzereingabe und der Menüsysteme. 2) Die Syntax der DO-While-Schleife kann jedoch bei Neulingen Verwirrung verursachen und unnötige Leistungsaufwand verleihen.

Wie kann man in PHP Saiten hasht?Wie kann man in PHP Saiten hasht?May 15, 2025 pm 08:54 PM

Effiziente Hashing -Zeichenfolgen in PHP können die folgenden Methoden verwenden: 1. Verwenden Sie die MD5 -Funktion für schnelles Hashing, eignen sich jedoch nicht für den Kennwortspeicher. 2. Verwenden Sie die SHA256 -Funktion, um die Sicherheit zu verbessern. 3.. Verwenden Sie die Funktion password_hash, um Passwörter zu verarbeiten, um die höchste Sicherheit und Bequemlichkeit zu gewährleisten.

Wie implementieren Sie ein Array -Schiebebefenster in PHP?Wie implementieren Sie ein Array -Schiebebefenster in PHP?May 15, 2025 pm 08:51 PM

Durch die Implementierung eines Array -Schieberfensters in PHP kann durch Funktionen Diawindow und SlideWindowaverage durchgeführt werden. 1. Verwenden Sie die Diawindow-Funktion, um ein Array in ein Subarray mit fester Größe aufzuteilen. 2. Verwenden Sie die SlideWindowAverage -Funktion, um den Durchschnittswert in jedem Fenster zu berechnen. 3. Für Echtzeitdatenströme können asynchrone Verarbeitung und Ausreißererkennung unter Verwendung von ReactPHP verwendet werden.

Wie verwende ich die __clone -Methode in PHP?Wie verwende ich die __clone -Methode in PHP?May 15, 2025 pm 08:48 PM

Die __clone -Methode in PHP wird verwendet, um benutzerdefinierte Operationen beim Klonen von Objekten durchzuführen. Beim Klonen eines Objekts mit dem Klonschlüsselwort wird die Methode automatisch aufgerufen.

Wie benutze ich die GOTO -Anweisung in PHP?Wie benutze ich die GOTO -Anweisung in PHP?May 15, 2025 pm 08:45 PM

In PHP werden GOTO -Aussagen verwendet, um bedingungslos zu bestimmten Tags im Programm zu springen. 1) Es kann die Verarbeitung komplexer verschachtelter Schleifen oder bedingten Aussagen vereinfachen. 2) 2) Die Verwendung von GOTO kann den Code schwer zu verstehen und zu warten, und 3) wird empfohlen, die Verwendung strukturierter Kontrollanweisungen vorrangig zu machen. Insgesamt sollte GOTO mit Vorsicht verwendet werden und Best Practices werden befolgt, um die Lesbarkeit und Wartbarkeit des Codes zu gewährleisten.

Wie implementieren Sie Datenstatistiken in PHP?Wie implementieren Sie Datenstatistiken in PHP?May 15, 2025 pm 08:42 PM

In PHP können Datenstatistiken mit integrierten Funktionen, benutzerdefinierten Funktionen und Bibliotheken von Drittanbietern erreicht werden. 1) Verwenden Sie integrierte Funktionen wie array_sum () und count (), um grundlegende Statistiken durchzuführen. 2) Schreiben Sie benutzerdefinierte Funktionen, um komplexe Statistiken wie Mediane zu berechnen. 3) Verwenden Sie die PHP-ML-Bibliothek, um eine erweiterte statistische Analyse durchzuführen. Durch diese Methoden können Datenstatistiken effizient durchgeführt werden.

Wie benutze ich anonyme Funktionen in PHP?Wie benutze ich anonyme Funktionen in PHP?May 15, 2025 pm 08:39 PM

Ja, anonyme Funktionen in PHP beziehen sich auf Funktionen ohne Namen. Sie können als Parameter an andere Funktionen und als Rückgabewerte von Funktionen übergeben werden, wodurch der Code flexibler und effizienter wird. Bei Verwendung anonymer Funktionen müssen Sie auf Umfangs- und Leistungsprobleme achten.

See all articles

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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Nordhold: Fusionssystem, erklärt
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools