Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimana untuk Membandingkan Senarai Objek Tidak Tertib dengan Cekap?

Bagaimana untuk Membandingkan Senarai Objek Tidak Tertib dengan Cekap?

Linda Hamilton
Lepaskan: 2024-11-27 06:12:13
asal
365 orang telah melayarinya

How to Efficiently Compare Unordered Lists of Objects?

Perbandingan Cekap Senarai Tidak Tersusun

Membandingkan senarai tidak tersusun, juga dikenali sebagai beg, boleh menjadi tugas yang mencabar, terutamanya apabila bekerja dengan objek dan bukannya jenis data ringkas seperti integer . Berikut ialah tiga pendekatan cekap untuk menangani masalah ini:

1. Kaedah Kaunter (O(n))

Untuk objek yang boleh dicincang (iaitu, boleh ditukar kepada nilai cincang yang unik), kaedah Counter() daripada modul koleksi Python boleh digunakan. Ia mencipta objek seperti kamus di mana kunci ialah elemen senarai dan nilai adalah kiraan masing-masing. Membandingkan dua senarai menggunakan pendekatan ini mempunyai kerumitan masa linear O(n), dengan n ialah panjang senarai.

import collections

def compare(s, t):
    return collections.Counter(s) == collections.Counter(t)
Salin selepas log masuk

2. Kaedah Isih (O(n log n))

Jika objek dalam senarai adalah setanding (iaitu, ia mempunyai susunan yang ditentukan), mengisih senarai boleh menyediakan mekanisme perbandingan yang cekap. Kaedah sorted() dalam Python menyusun elemen dalam senarai, menjadikannya mudah untuk menentukan sama ada kedua-dua senarai mengandungi elemen yang sama dalam sebarang susunan. Pendekatan ini mempunyai kerumitan masa O(n log n), dengan n ialah panjang senarai.

def compare(s, t):
    return sorted(s) == sorted(t)
Salin selepas log masuk

3. Perbandingan Kesaksamaan (O(n * n))

Jika objek tidak boleh dicincang dan tidak boleh diatur, pendekatan yang mudah ialah melakukan perbandingan kesaksamaan antara elemen kedua-dua senarai. Untuk setiap elemen dalam senarai pertama, kami mengeluarkannya daripada senarai kedua. Jika mana-mana elemen dalam senarai pertama tidak ditemui dalam senarai kedua, perbandingan gagal. Pendekatan ini mempunyai kerumitan masa terburuk O(n * n), dengan n ialah panjang senarai.

def compare(s, t):
    t = list(t)  # make a mutable copy
    try:
        for elem in s:
            t.remove(elem)
    except ValueError:
        return False
    return not t
Salin selepas log masuk

Dengan menggunakan teknik perbandingan yang cekap ini, anda boleh membandingkan senarai objek yang tidak tertib dengan berkesan , sama ada ia boleh dicincang, boleh dipesan atau tidak.

Atas ialah kandungan terperinci Bagaimana untuk Membandingkan Senarai Objek Tidak Tertib dengan Cekap?. 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