cari
Rumahpembangunan bahagian belakangTutorial PythonKemunculan Susun Atur Linen Hari Kod

Advent of Code  Day  Linen Layout

Hari 19: Susun Atur Linen

Penyelesaian GitHub

Cabaran hari ini ialah perubahan yang menyegarkan daripada teka-teki 2D biasa dan algoritma Dijkstra. Begini cara saya mendekatinya:

Bahagian 1

Matlamatnya mudah: semak sama ada susunan tuala yang diberikan boleh dibuat menggunakan tuala yang tersedia.

Apa yang TIDAK boleh dilakukan:

Pada mulanya, saya cuba menjana semua kombinasi tuala yang mungkin dengan itertools.combinations. Ia dengan cepat menjadi jelas bahawa ini tidak praktikal atau cekap.

Apa yang berjaya:

Menggunakan rekursi digabungkan dengan kamus (memo) untuk cache reka bentuk yang telah diproses. Ini menghalang pengiraan berlebihan dan menjadikan penyelesaian lebih cekap.

Cara ia berfungsi:

Untuk setiap reka bentuk, cuba padankan permulaan dengan salah satu corak tuala.
Jika terdapat padanan, tanggalkan bahagian yang dipadankan dan ulangi pada bakinya.
Gunakan memo untuk cache hasil untuk reka bentuk yang telah kami semak, mengelakkan kerja pendua.
Pendekatan rekursif dengan memoisasi memastikan kerumitan terurus, walaupun untuk input yang lebih besar, dan menjadikan penyelesaian berjalan dengan cekap.

Bahagian 2
Bahagian kedua telah meningkatkan keputusan: kira bilangan cara untuk membuat setiap reka bentuk tuala menggunakan corak yang tersedia.

Wawasan utama:
Fungsi count_arrangement memanjangkan logik rekursif dari Bahagian 1, tetapi kini mengira semua cara yang mungkin untuk membina reka bentuk.

Untuk setiap tuala yang sepadan, ulangi pada baki reka bentuk.
Gunakan kamus lain (memo_count) untuk cache hasil bagi submasalah yang telah diselesaikan sebelum ini.

Contoh:
Jika "brgr" boleh dibina dalam 2 cara, kami hanya mengembalikan 2 daripada cache dan bukannya mengira semula.

Pengoptimuman:
Terima kasih kepada Bahagian 1, kami sudah tahu reka bentuk mana yang mungkin. Kami hanya mengira perkiraan untuk mereka.

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

Dengan merumuskan semua cara yang sah, kami mendapat jawapan akhir untuk Bahagian 2, semudah itu.

Seperti yang saya katakan, saya mendapati cabaran hari ini agak menyeronokkan dan merupakan perubahan yang bagus. Saya harap artikel ini telah membantu untuk cabaran / pengekodan masa hadapan.

Seperti biasa, sila beri saya pengikut atau hubungi di Twitter

Atas ialah kandungan terperinci Kemunculan Susun Atur Linen Hari Kod. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Pendekatan Hibrid Python: Kompilasi dan Tafsiran DigabungkanPendekatan Hibrid Python: Kompilasi dan Tafsiran DigabungkanMay 08, 2025 am 12:16 AM

Pythonusesahybridapproach, combiningcompilationtobytecodeandinterpretation.1) codeiscompiledtopplatform-independentbytecode.2) byteCodeisinterpretedbythepythonvirtualmachine, enhancingficiencyAndortability.

Ketahui perbezaan antara gelung 'untuk' dan 'sementara' PythonKetahui perbezaan antara gelung 'untuk' dan 'sementara' PythonMay 08, 2025 am 12:11 AM

TheKeydifferencesbetweenpython's "for" and "while" loopsare: 1) "untuk" loopsareidealforiteratingoversequencesorknowniterations, while2) "manakala" loopsarebetterforcontinuinguntilaconditionismetwithoutpredefinediterations.un

Senarai concatenate python dengan penduaSenarai concatenate python dengan penduaMay 08, 2025 am 12:09 AM

Di Python, anda boleh menyambungkan senarai dan menguruskan elemen pendua melalui pelbagai kaedah: 1) Gunakan pengendali atau melanjutkan () untuk mengekalkan semua elemen pendua; 2) Tukar ke set dan kemudian kembali ke senarai untuk mengalih keluar semua elemen pendua, tetapi pesanan asal akan hilang; 3) Gunakan gelung atau senarai pemantauan untuk menggabungkan set untuk menghapuskan elemen pendua dan mengekalkan urutan asal.

Python List Concatenation Prestasi: Perbandingan KelajuanPython List Concatenation Prestasi: Perbandingan KelajuanMay 08, 2025 am 12:09 AM

ThfastestmethodforlistconcatenationInpythondondedonListsize: 1) forsmalllists, the operatoriseSefficient.2) forlargerlists, list.extend () orlistComprehensionisfaster, withExtend () ausmorememory-efficientyModifingListsin-tempat.

Bagaimana anda memasukkan elemen ke dalam senarai python?Bagaimana anda memasukkan elemen ke dalam senarai python?May 08, 2025 am 12:07 AM

ToinSertelementsIntoapythonlist, useAppend () toaddtotheend, memasukkan () foraspecificposition, andExtend () formultipleelements.1) useAppend () foraddingsingleitemstotheend.2) useInsert () toaddataSpecificIndex, evenItForForForForForForShoStoRd

Adakah Python menyenaraikan susunan dinamik atau senarai yang dipautkan di bawah tudung?Adakah Python menyenaraikan susunan dinamik atau senarai yang dipautkan di bawah tudung?May 07, 2025 am 12:16 AM

Pythonlistsareimplementedasdynamicarrays, notlinkedlists.1) thearestoredincontiguousmemoryblocks, yangMayrequireReAllocationWhenAppendingItems, ImpactingPormance.2) LinkedListSwouldOfferefficientInsertions/DeletionsButsCoweCcess

Bagaimana anda membuang elemen dari senarai python?Bagaimana anda membuang elemen dari senarai python?May 07, 2025 am 12:15 AM

PythonoffersfourmainmethodstoremoveelementsFromalist: 1) Keluarkan (nilai) RemoveStHefirStoccurrenceFavalue, 2) Pop (index) RemoveRandReturnSanelementAtaspeciedIndex, 3)

Apa yang perlu anda periksa jika anda mendapat ralat 'kebenaran ditolak' apabila cuba menjalankan skrip?Apa yang perlu anda periksa jika anda mendapat ralat 'kebenaran ditolak' apabila cuba menjalankan skrip?May 07, 2025 am 12:12 AM

Ralat toresolvea "kebenaran" yang mana -mana, berikut: 1) checkandadjustthescript'spermissionsingchmod xmyscript.shtomakeitexecutable.2) EnsurethescriptislocatedInadirectoryHeryouhaveVerPiSs, suchasyoursory, suchasyourshy, suchasyourperhysh, suchasyourshy.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna