Mengimbangi Pengagihan Senarai dengan Teknik Pemisahan yang Cekap
Dalam bidang manipulasi data, keupayaan untuk mengagihkan senarai secara sama rata kepada beberapa bahagian panjang yang dikehendaki memegang kepentingan yang penting. Cabaran ini timbul dalam pelbagai senario, seperti apabila membahagikan data untuk pemprosesan serentak atau menyusun item kepada subset yang boleh diurus.
Satu pendekatan yang biasa digunakan ialah fungsi chunks(), yang membahagikan senarai kepada ketulan saiz tertentu. Walau bagaimanapun, kaedah ini tidak mempunyai ketepatan untuk mencipta bahagian yang hampir sama dalam semua kes. Contohnya, apabila membahagikan senarai 7 elemen kepada 2 bahagian, ia akan menghasilkan ketulan 3 dan 4 elemen yang tidak sekata.
Untuk menangani had ini, penyelesaian yang lebih halus dibentangkan:
def split(a, n): k, m = divmod(len(a), n) return (a[i*k+min(i, m):(i+1)*k+min(i+1, m)] for i in range(n))
Pendekatan ini menggunakan fungsi divmod() untuk mengira bilangan ketulan lengkap saiz k dan bilangan elemen dalam ketulan separa m yang tinggal. Selepas itu, gelung berulang melalui setiap bahagian, bermula dari indeks i, dan menghiris senarai untuk mendapatkan semula subset yang diingini.
Sebagai ilustrasi, pertimbangkan contoh berikut:
>>> list(split(range(11), 3)) [[0, 1, 2, 3], [4, 5, 6, 7], [8, 9, 10]]
Dalam ini senario, senarai [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] dibahagikan secara elegan kepada tiga bahagian yang hampir sama, dengan setiap ketulan mengandungi sama ada 4 atau 3 elemen.
Dengan memasukkan teknik ini ke dalam senjata pengaturcaraan anda, anda akan memperoleh alat yang berkuasa untuk menguruskan senarai dengan cekap dan seimbang cara.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Membahagikan Senarai kepada Bahagian Seimbang dengan Teknik yang Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!