


Zeichensätze und -schichten: Effizient eindeutige Permutationen erzeugen
In diesem Artikel wird untersucht, wie eine Permutationskombination ohne Duplikate und ohne aufeinanderfolgende identische Zeichen basierend auf einem bestimmten Zeichensatz und der Anzahl der Ebenen erzeugt wird. Zum Beispiel sollte der Charakter-Set {A, B}, die dreischichtige Permutationskombination AAB, ABA, ABB, BAA, BAB, BBA usw. enthalten, aber nicht AAA, BBB und andere aufeinanderfolgende wiederholte Charaktere. Dies erfordert Algorithmen, um die Deduplizierung zu bewältigen und eine kontinuierliche Vervielfältigung von Zeichen zu vermeiden.
Die zentrale Herausforderung besteht darin, einen Algorithmus zu entwerfen, der sich an verschiedene Zeichensätze und -schichten anpassen und effizient Permutationen erzeugt, die den Kriterien entsprechen. In diesem Artikel werden zwei Methoden eingeführt: Methode für digitale Ersatz- und Backtracking -Methoden.
Methode 1: Methode für digitale Ersatz
Diese Methode behandelt die Permutationskombination als m-Digit-Zahl (M ist die Zeichensatzgröße). Zum Beispiel entspricht der Zeichensatz {A, B} einer Binärzahl. 00 repräsentiert AA, 01 repräsentiert AB und so weiter. Durch das Durchqueren aller m-Digit-Zahlen und das Ersetzen von Zeichen können Sie alle möglichen Kombinationen erhalten. Um kontinuierliche identische Zeichen zu vermeiden, müssen bestimmte m-Digit-Zahlen ausgeschlossen werden, z. B. Zahlen, bei denen alle Bits gleich sind.
Beispiel für Python -Code:
Def Solve_Digit (arr, m, degling_all_Same = false): res, cur = [], [''] * m n = len (arr) All_Same_Num = 0 für _ im Bereich (m): All_Same_Num = All_Same_Num * n 1 für D in Reichweite (N ** m): Wenn erlaubt_all_Same oder d % All_Same_Num! = 0: für i in Reichweite (m -1, -1, -1): cur [i] = arr [d % n] d // = n res.Append (''. Join (cur)) Return res print (LELVE_DIGIT ('AB', 2)) # ['AB', 'BA'] print (LELVE_DIGIT ('AB', 2, TRUE) # ['AA', 'AB', 'BA', 'BB'] print (LELVE_DIGIT ('AB', 3)) # ['AAB', 'Aba', 'abb', 'baa', 'bab', 'bba'] print (LELVE_DIGIT ('ABC', 2)) # ['AB', 'AC', 'BA', 'BC', 'CA', 'CB']
Methode 2: Backtracking -Methode
Backtrace ist ein rekursiver Algorithmus, der Ergebnisse findet, indem alle möglichen Kombinationen ausprobieren. Fügen Sie der aktuellen Kombination bei jedem Schritt ein Zeichen hinzu und erzeugen rekursiv längere Kombinationen. Gleichzeitig ist es notwendig zu verfolgen, ob die vorherigen Zeichen gleich sind, um Kombinationen zu vermeiden, die den Bedingungen nicht erfüllen.
Beispiel für Python -Code:
Def Solve_backTracking (arr, m, dego_all_Same = false): res, cur = [], [''] * m def dfs (i, gleich): Wenn ich == m: Wenn nicht gleich: res.Append (''. Join (cur)) Zurückkehren für ein in arr: cur [i] = a DFS (i 1, gleich und a == cur [i - 1]) für ein in arr: cur [0] = a DFS (1, nicht zulässt_all_Same) Return res print (LELVE_BACKTRACKING ('AB', 2)) # ['AB', 'BA'] print (LELVE_BACKTRACKING ('AB', 2, TRUE)) # ['AA', 'AB', 'BA', 'BB'] print (LELVE_BACKTRACKING ('AB', 3)) # ['AAB', 'Aba', 'Abb', 'Baa', 'Bab', 'BBA'] print (LELVE_BACKTRACKING ('ABC', 2)) # ['AB', 'AC', 'BA', 'BC', 'CA', 'CB']
Beide Methoden können das Problem lösen. Die digitale Ersatzmethode ist effizienter und die Backtracking -Methode ist einfacher zu verstehen. Welche Methode zu wählen, hängt vom spezifischen Anwendungsszenario und den persönlichen Vorlieben ab.
Das obige ist der detaillierte Inhalt vonWie generiert man eine Permutationskombination, die sich nicht wiederholt und nicht zusammenhängende identische Zeichen basierend auf einem bestimmten Zeichensatz und der Anzahl der Ebenen basiert?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Um die Anwendung vor Sitzungsangriffen im Zusammenhang mit den Sitzungen zu schützen, sind folgende Maßnahmen erforderlich: 1. Stellen Sie die HTTPonly- und sicheren Flags ein, um die Sitzungs Cookies zu schützen. 2. Exportcodes für alle Benutzereingaben. 3. Implementieren Sie die Inhaltssicherheitsrichtlinie (CSP), um die Skriptquellen einzuschränken. Durch diese Richtlinien können Sitzungsangriffe im Zusammenhang mit Sitzungen effektiv geschützt und Benutzerdaten sichergestellt werden.

Methoden zur Optimierung der PHP -Sitzungsleistung gehören: 1. Start der Verzögerung der Sitzung, 2. Verwenden Sie Datenbank zum Speichern von Sitzungen, 3. Kompress -Sitzungsdaten, 14. Sitzungslebenszyklus verwalten und 5. Sitzungsfreigabe implementieren. Diese Strategien können die Effizienz von Anwendungen in hohen Parallelitätsumgebungen erheblich verbessern.

Thesession.gc_maxlifetimesettingInphpdeterminesthelifspanofSessionData, setInseconds.1) ItsconfiguredInphp.iniorviaini_Set (). 2) AbalanceIsneedToAvoidPerformanceSandunexexwortedyg -Probablogouts

In PHP können Sie die Funktion Session_name () verwenden, um den Sitzungsnamen zu konfigurieren. Die spezifischen Schritte sind wie folgt: 1. Verwenden Sie die Funktion Session_name (), um den Sitzungsnamen wie Session_name ("my_Session") festzulegen. 2. Nachdem Sie den Sitzungsnamen festgelegt haben, call Session_start (), um die Sitzung zu starten. Das Konfigurieren von Sitzungsnamen kann Sitzungsdatenkonflikte zwischen mehreren Anwendungen vermeiden und die Sicherheit verbessern, aber auf die Einzigartigkeit, Sicherheit, Länge und Festlegen des Zeitpunkts der Sitzungsnamen achten.

Die Sitzungs -ID sollte regelmäßig bei Anmeldung, vor sensiblen Operationen und alle 30 Minuten regeneriert werden. 1. Regenerieren Sie die Sitzungs -ID, wenn Sie sich anmelden, um festgelegte Angriffe zu verhindern. 2.. Genieren Sie vor sensiblen Operationen, um die Sicherheit zu verbessern. 3. Die regelmäßige Regeneration reduziert das langfristige Nutzungsrisiko, aber die Benutzererfahrung muss abgewogen werden.

Das Einstellen von Sitzungs -Cookie -Parametern in PHP kann über die Funktion Session_set_cookie_params () erreicht werden. 1) Verwenden Sie diese Funktion, um Parameter wie Ablaufzeit, Pfad, Domänenname, Sicherheitsflag usw. Zu setzen; 2) Call Session_start (), um die Parameter wirksam zu machen; 3) Parameter dynamisch entsprechend den Anforderungen wie dem Benutzeranmeldestatus des Benutzers einstellen. 4) Achten Sie darauf, sichere und httponly -Flags festzulegen, um die Sicherheit zu verbessern.

Der Hauptzweck bei der Verwendung von Sitzungen in PHP besteht darin, den Status des Benutzers zwischen verschiedenen Seiten aufrechtzuerhalten. 1) Die Sitzung wird über die Funktion Session_start () gestartet, wodurch eine eindeutige Sitzungs -ID erstellt und im Benutzer Cookie gespeichert wird. 2) Sitzungsdaten werden auf dem Server gespeichert, sodass Daten zwischen verschiedenen Anforderungen wie Anmeldestatus und Einkaufswagen -Inhalten übergeben werden können.

Wie teile ich eine Sitzung zwischen Subdomains? Implementiert durch Einstellen von Sitzungs Cookies für gemeinsame Domainnamen. 1. Setzen Sie die Domäne des Sitzungs -Cookie auf .example.com auf der Serverseite. 2. Wählen Sie die entsprechende Sitzungsspeichermethode wie Speicher, Datenbank oder verteiltes Cache. 3. Übergeben Sie die Sitzungs -ID über Cookies, und der Server ruft und aktualisiert die Sitzungsdaten basierend auf der ID.


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

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

Heißer Artikel

Heiße Werkzeuge

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

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

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)