suchen
HeimBackend-EntwicklungPython-TutorialEinführung des Code-Day-Leinenlayouts

Advent of Code  Day  Linen Layout

Tag 19: Leinenlayout

GitHub-Lösung

Die heutige Herausforderung war eine erfrischende Abwechslung zu den üblichen 2D-Rätseln und Dijkstras Algorithmen. So bin ich vorgegangen:

Teil 1

Das Ziel war einfach: Prüfen Sie, ob die vorgegebenen Handtuchanordnungen mit den verfügbaren Handtüchern erstellt werden können.

Was Sie NICHT tun sollten:

Zunächst habe ich versucht, alle möglichen Handtuchkombinationen mit itertools.combinations zu generieren. Es wurde schnell klar, dass dies weder praktisch noch effizient war.

Was hat funktioniert:

Verwendung von Rekursion in Kombination mit einem Wörterbuch (Memo), um bereits verarbeitete Designs zwischenzuspeichern. Dies verhindert redundante Berechnungen und macht die Lösung wesentlich effizienter.

So funktioniert es:

Versuchen Sie bei jedem Design, den Anfang mit einem der Handtuchmuster abzugleichen.
Wenn es eine Übereinstimmung gibt, entfernen Sie den übereinstimmenden Teil und rekursieren Sie für den Rest.
Verwenden Sie Memo, um Ergebnisse für Designs, die wir bereits überprüft haben, zwischenzuspeichern und so doppelte Arbeit zu vermeiden.
Der rekursive Ansatz mit Memoisierung hält die Komplexität auch bei größeren Eingaben beherrschbar und sorgt dafür, dass die Lösung effizient läuft.

Teil 2
Der zweite Teil ging noch einen Schritt weiter: Zählen Sie die Anzahl der Möglichkeiten, jedes Handtuchdesign anhand der verfügbaren Muster herzustellen.

Wichtige Erkenntnisse:
Die Funktion count_arrangements erweitert die rekursive Logik aus Teil 1, berechnet nun aber alle möglichen Wege zum Aufbau eines Designs.

Für jedes passende Handtuch wiederholen Sie den Rest des Designs.
Verwenden Sie ein anderes Wörterbuch (memo_count), um Ergebnisse für zuvor gelöste Teilprobleme zwischenzuspeichern.

Beispiel:
Wenn „brgr“ auf zwei Arten erstellt werden kann, geben wir einfach 2 aus dem Cache zurück, anstatt es neu zu berechnen.

Optimierung:
Dank Teil 1 wissen wir bereits, welche Designs möglich sind. Wir berechnen nur Arrangements für diese.

for arrangement in arrangements:
    if arrangement in memo and memo[arrangement]:
        ways = count_arrangements(arrangement, towels, memo_count)
        total_arrangements += ways

Indem wir alle gültigen Möglichkeiten zusammenfassen, erhalten wir ganz einfach die endgültige Antwort für Teil 2.

Wie gesagt, die heutige Herausforderung hat mir sehr viel Spaß gemacht und war eine schöne Abwechslung. Ich hoffe, dieser Artikel hat bei zukünftigen Herausforderungen/Codierungen geholfen.

Folgen Sie mir wie immer gerne oder kontaktieren Sie mich auf Twitter

Das obige ist der detaillierte Inhalt vonEinführung des Code-Day-Leinenlayouts. 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
Pythons Hybridansatz: Zusammenstellung und Interpretation kombiniertPythons Hybridansatz: Zusammenstellung und Interpretation kombiniertMay 08, 2025 am 12:16 AM

Pythonusesahybridapproach, kombinierte CompilationTobyteCodeAnDinterpretation.1) codiscompiledtoplatform-unintenpendentBytecode.2) BytecodeIsinterpretedBythepythonvirtualMachine, EnhancingEfficiency und Portablabilität.

Erfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsErfahren Sie die Unterschiede zwischen Pythons 'für' und 'while the' LoopsMay 08, 2025 am 12:11 AM

Die Keedifferzences -zwischen Pythons "für" und "während" Loopsare: 1) "für" LoopsareideAlForiteratingOvercesorknownowniterations, während 2) "LoopsarebetterForContiningUtilAconditionismethoutnredefineditInations.un

Python verkettet Listen mit DuplikatenPython verkettet Listen mit DuplikatenMay 08, 2025 am 12:09 AM

In Python können Sie Listen anschließen und doppelte Elemente mit einer Vielzahl von Methoden verwalten: 1) Verwenden von Operatoren oder erweitert (), um alle doppelten Elemente beizubehalten; 2) Konvertieren in Sets und kehren Sie dann zu Listen zurück, um alle doppelten Elemente zu entfernen. Die ursprüngliche Bestellung geht jedoch verloren. 3) Verwenden Sie Schleifen oder listen Sie Verständnisse auf, um Sätze zu kombinieren, um doppelte Elemente zu entfernen und die ursprüngliche Reihenfolge zu verwalten.

Python List -Verkettungsleistung: GeschwindigkeitsvergleichPython List -Verkettungsleistung: GeschwindigkeitsvergleichMay 08, 2025 am 12:09 AM

THESTESTMETHODFORLISTCONCATENATIONINPYTHONDSONLISTSIZE: 1) ForsmallLists, The Operatoriseffiction.2) Forlargerlists, list.extend () orlistCompretInsisfaster, WithEttend () MORMOREMEIMIENTIENTIENTYMODIFICIENTLISTLISTERSIN-SPACE.

Wie setzen Sie Elemente in eine Python -Liste ein?Wie setzen Sie Elemente in eine Python -Liste ein?May 08, 2025 am 12:07 AM

ToInsertElementsIntoapherthonList, useAppend () toaddtotheend, insert () foraspecificposition und fortend () formulpulpulements.1) useeAppend () Foraddingsingleiitemstotheend.2) useInsert () toaddataspecificIndex, zwarsititithulsForlargerists

Sind Python -Listen dynamische Arrays oder verknüpfte Listen unter der Haube?Sind Python -Listen dynamische Arrays oder verknüpfte Listen unter der Haube?May 07, 2025 am 12:16 AM

PythonlistsarEmplementedasdynamicArrays, Notlinkedlists.1) Sie haben incontuituousMemoryblocks, die ausgelöst werden, wobei die Auswirkungen auf die Erfüllung von Zeitungen/Deletionsbutionen, die in Verbindung gebracht wurden

Wie entfernen Sie Elemente aus einer Python -Liste?Wie entfernen Sie Elemente aus einer Python -Liste?May 07, 2025 am 12:15 AM

PythonoffersfourmainMethodstoremoveLements Fromalist: 1) Entfernen (Wert) removesthefirstoccurceofavalue, 2) Pop (index) removesandreturnsanelementataspecifiedIndex, 3) DelstatementRemovesElementsbyIntexors und 4) clear () removesallitems

Was sollten Sie überprüfen, wenn Sie einen Fehler 'Erlaubnis abgelehnt' erhalten, wenn Sie versuchen, ein Skript auszuführen?Was sollten Sie überprüfen, wenn Sie einen Fehler 'Erlaubnis abgelehnt' erhalten, wenn Sie versuchen, ein Skript auszuführen?May 07, 2025 am 12:12 AM

ToreSolvea "Berechtigte" FehlerwherunningAscript, folgen von THESESTEPS: 1) checkandadjustThescript'SPERMISSIONSCHMOD XMYSCRIPT.SHTOMAKEPEXEx.

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ße Werkzeuge

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

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),

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen