Permutasi Padanan Senarai Berbeza Panjang
Dalam bidang pengaturcaraan, cabaran biasa timbul apabila berurusan dengan dua senarai panjang yang berbeza-beza, berusaha untuk memadankan elemen mereka dalam kombinasi tertentu.
Pertimbangkan senario berikut: diberi dua senarai, nama dan nombor, di mana len(nama) >= len(nombor), tugasnya adalah untuk menghasilkan tupel yang mengandungi semua kemungkinan gabungan unsur daripada senarai yang lebih panjang (nama) dengan unsur daripada senarai yang lebih pendek (nombor).
Contoh:
Jika nama = ['a', 'b '] dan nombor = [1, 2], output yang dijangkakan ialah:
Penyelesaian:
Pendekatan paling mudah untuk menangani masalah ini ialah dengan menggunakan fungsi itertools.product daripada perpustakaan standard Python. Fungsi ini menjana produk Cartesian bagi elemen dalam senarai yang disediakan.
Kod:
<code class="python">import itertools a = ['foo', 'melon'] b = [True, False] c = list(itertools.product(a, b)) print(c)</code>
Output:
[('foo', True), ('foo', False), ('melon', True), ('melon', False)]
Dengan menggunakan itertools.product, kami boleh menjana dengan cekap semua kemungkinan gabungan elemen daripada dua senarai, tanpa mengira perbezaan panjangnya. Teknik ini menawarkan penyelesaian yang mudah dan ringkas kepada masalah yang diberikan.
Atas ialah kandungan terperinci Berikut ialah beberapa pilihan tajuk, berbeza dari segi formaliti dan keterusterangan: rasmi: * Cara Menjana Semua Pilihatur Padanan Senarai dengan Panjang Berbeza * Memadankan Elemen Secara Cekap daripada Berbeza-. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!