Isih Senarai Senarai dalam Susunan Selang Seli
Diberikan senarai yang mengandungi subsenarai dalam format [['a',1], [' a',2], ['a',3], ['b',1], ['b',2], ['b',3]], matlamatnya adalah untuk mengisih subsenarai ini secara berselang-seli , dengan elemen 0 diisih dalam tertib menurun dan elemen 1 diisih dalam tertib menaik. Hasil yang dijangkakan ialah [['b',1], ['b',2], ['b',3], ['a',1], ['a',2], ['a', 3]].
Untuk mencapai ini, seseorang boleh memanfaatkan fungsi sort() dengan kunci tersuai. Kuncinya ialah fungsi lambda yang mengekstrak unsur-unsur yang menarik dan menggunakan operasi isihan padanya. Dalam kes ini, ia mendapatkan semula elemen pertama setiap subsenarai, menggunakan isihan menurun, dan kemudian menggabungkannya dengan negatif elemen kedua, diisih dalam tertib menaik. Dengan membalikkan susunan isihan dengan reverse=True, subsenarai diisih mengikut elemen pertama dan menaik mengikut elemen kedua. Ini menghasilkan tertib berselang-seli yang diingini.
Coretan kod berikut menunjukkan penyelesaiannya:
<code class="python">L = [['a',1], ['a',2], ['a',3], ['b',1], ['b',2], ['b',3]] L.sort(key=lambda k: (k[0], -k[1]), reverse=True) print(L) # [['b', 1], ['b', 2], ['b', 3], ['a', 1], ['a', 2], ['a', 3]]</code>
Atas ialah kandungan terperinci Bagaimana untuk Mengisih Senarai Senarai dalam Susunan Bergantian dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!