Pengiraan Frekuensi Item dalam Python
Bagaimanakah anda cekap mengira kejadian setiap perkataan unik dalam senarai yang diberikan? Pertimbangkan kod berikut:
<code class="python">words = "apple banana apple strawberry banana lemon" uniques = set(words.split()) freqs = [(item, words.split().count(item)) for item in uniques] print(freqs)</code>
Semasa kaedah ini berfungsi, ia memerlukan dua lelaran melalui senarai, sekali untuk mencipta set perkataan unik dan sekali lagi untuk mengira penampilan. Bolehkah kita mengoptimumkan ini?
Penyelesaian: Menggunakan Kelas Kaunter
Modul koleksi Python menyediakan kelas Kaunter yang direka khusus untuk tugasan ini. Begini cara anda boleh menggunakannya:
<code class="python">from collections import Counter words = "apple banana apple strawberry banana lemon" Counter(words.split()) # Output: Counter({'apple': 2, 'banana': 2, 'strawberry': 1, 'lemon': 1})</code>
Kelas Counter mengira kejadian setiap item dalam lelaran yang disediakan, menghasilkan kamus di mana kunci adalah item unik dan nilai adalah kiraan mereka. Pendekatan ini lebih cekap kerana ia hanya memerlukan satu lelaran melalui senarai input.
Atas ialah kandungan terperinci Bagaimana untuk Mengira Kejadian Perkataan dengan Cekap dalam Senarai Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!