Bagaimana untuk Cekap Mencari Elemen Paling Lazim dalam Senarai Python, Walaupun Dengan Item Tidak Boleh Hash?

Susan Sarandon
Lepaskan: 2024-11-24 15:02:11
asal
275 orang telah melayarinya

How to Efficiently Find the Most Common Element in a Python List, Even With Non-Hashable Items?

Mencari Elemen Paling Lazim dalam Senarai Dengan Cekap

Dalam Python, menentukan elemen yang paling kerap muncul dalam senarai boleh menimbulkan cabaran, terutamanya apabila item senarai tidak boleh dicincang. Untuk menangani perkara ini, kami membentangkan pendekatan cekap yang mengutamakan item dengan indeks paling rendah sekiranya berlaku ikatan.

Pertimbangkan fungsi Python berikut:

def most_common(lst):
    return max(set(lst), key=lst.count)
Salin selepas log masuk

Fungsi ini beroperasi dengan menghapuskan pendua daripada senarai input lst dengan menukarnya kepada set. Fungsi max() kemudiannya digunakan untuk mengenal pasti elemen dengan kiraan tertinggi daripada set. Parameter utama menentukan bahawa perbandingan hendaklah berdasarkan kiraan setiap elemen, seperti yang ditentukan oleh kaedah lst.count.

Untuk menggambarkan, pertimbangkan contoh ini:

>>> most_common(['duck', 'duck', 'goose'])
'duck'
Salin selepas log masuk

Dalam ini contohnya, 'itik' berlaku dua kali, manakala 'angsa' muncul sekali sahaja. Oleh itu, 'itik' dikembalikan sebagai elemen yang paling biasa.

>>> most_common(['goose', 'duck', 'duck', 'goose'])
'goose'
Salin selepas log masuk

Dalam senario ini, kedua-dua 'angsa' dan 'itik' berlaku dua kali. Walau bagaimanapun, memandangkan 'angsa' mempunyai indeks yang lebih rendah, ia dikembalikan sebagai elemen yang paling biasa.

Pendekatan ini berkesan mencari elemen yang paling biasa dalam senarai, walaupun apabila elemen tidak boleh dicincang, dan ia mengutamakan item dengan indeks terendah sekiranya berlaku ikatan.

Atas ialah kandungan terperinci Bagaimana untuk Cekap Mencari Elemen Paling Lazim dalam Senarai Python, Walaupun Dengan Item Tidak Boleh Hash?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan