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!

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

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

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.

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

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

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

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

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


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

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
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

Dreamweaver CS6
Alat pembangunan web visual

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna
