Hari 22: Pasar Monyet
Repo GitHub
Teka-teki hari ini agak menyeronokkan kerana ia agak lurus ke hadapan. Banyak perkara yang perlu dilakukan adalah dalam arahan, iaitu beberapa manipulasi integer dan kemudian jumlah mudah (sekurang-kurangnya untuk Bahagian 1).
Kod ini agak lurus ke hadapan, kami menjalankan gelung 2,000 kali, setiap kali menyimpan nombor rahsia baharu, jadi kami boleh merumuskannya pada penghujungnya.
Ok jadi yang ini mengambil sedikit lebih kuasa otak, tetapi sekali lagi banyak logik dalam arahan.
Salah satu perbezaan terbesar ialah fungsi calc_price_changes(). Fungsi ini memproses urutan nombor dan hanya mengira "perubahan harga" untuk mengenal pasti corak.
Mari menyelam lebih dekat:
Fungsi calc_price_changes:
Memproses senarai "rahsia yang dihasilkan".
Mengira perubahan dalam "harga" (digit terakhir setiap rahsia).
Mengenal pasti corak unik 4 perubahan berturut-turut.
4.Mengagregatkan skor berdasarkan corak ini.
Ia memerlukan dua hujah:
Senarai nombor (mewakili rahsia yang dijana) serta objek seperti kamus (defaultdictcr) untuk menyimpan dan mengagregat markah untuk corak unik.
Dikte lalai ialah alat yang sangat berguna. Ia berfungsi seperti kamus biasa tetapi dengan kelebihan utama. Jika ia tidak menjumpai kunci dalam kamus, ia akan mengendalikan penciptaan kunci dan memberikannya nilai lalai bagi jenis yang diluluskan.
for p in range(len(price_change_sequence) - 4 + 1): changes = price_change_sequence[p: p + 4] key = tuple((changes[0][0], changes[1][0], changes[2][0], changes[3][0])) if key not in sequences: sequence_sum[key] += changes[3][1] sequences.add(key)
Kod di atas menggunakan tetingkap gelongsor 4 untuk mengekstrak kumpulan 4 tupel (perubahan, harga) berturut-turut.
Contoh: Jika jujukan_perubahan_harga ialah [(1, 5), (2, 7), (-1, 6), (3, 9)], satu “ketulan” ialah [(1, 5), (2, 7), (-1, 6), (3, 9)].
Kami kemudian mengekstrak hanya nilai perubahan daripada 4-tuple, cth -2,-1,1 dsb. Jika corak itu belum lagi dalam urutan, ia adalah corak baharu, jadi boleh menambah harga terakhir (perubahan[ 3][1]) kepada sequence_sum[pattern]. Tandai kekunci sebagai diproses dengan menambahkannya pada urutan yang ditetapkan.
Pada akhir fungsi:
sequence_sum mengandungi pemetaan corak 4-perubahan unik (seperti yang kami gunakan Set) kepada skor agregatnya (berdasarkan harga akhir dalam setiap jujukan).
Contoh: {(1, 2, -1, 3): 9, (-2, 0, 1, -1): 6}.
Katakan kami mempunyai input
generated_secrets = [45, 46, 50, 53, 58, 61] sequence_sum = defaultdict(int) calc_price_changes(generated_secrets, sequence_sum)
Langkah:
1. Kira Perubahan Harga:
Harga: [5, 6, 0, 3, 8, 1] (digit terakhir).
Perubahan: [(1, 6), (-6, 0), (3, 3), (5, 8), (-7, 1)]
Output:
{(1, -6, 3, 5): 8, (-6, 3, 5, -7): 1}
Begini cara semuanya bersatu:
Pemprosesan Input: Kami membaca dan menukar input kepada senarai nombor rahsia.
Penjanaan Jujukan: Untuk setiap rahsia, kami mengembangkannya secara berulang lebih 2000 generasi untuk menghasilkan jujukan nilai terbitan.
Analisis Perubahan Harga: Kami mengira perbezaan antara harga berturut-turut (digit terakhir) dalam jujukan, mengenal pasti corak 4 perubahan yang unik dan skor agregat untuk corak tersebut.
Pengeluaran Hasil: Akhirnya, kami menentukan corak yang paling berkesan dengan mencari corak yang mempunyai skor agregat tertinggi.
Dengan memecahkan masalah kepada langkah modular yang jelas, kami memproses data dengan cekap, menjejak corak dan menyelesaikan teka-teki.
Seperti biasa, saya harap ini telah membantu dan anda telah mempelajari sesuatu daripada penyelesaian saya. Jangan teragak-agak untuk meninggalkan pengikut, atau hubungi di Twitter
Atas ialah kandungan terperinci Kemunculan Pasar Monyet Hari Kod. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!