Rumah >pembangunan bahagian belakang >Tutorial Python >Apakah Cara Paling Cekap untuk Mencipta Senarai Item Tunggal Berulang dalam Python?

Apakah Cara Paling Cekap untuk Mencipta Senarai Item Tunggal Berulang dalam Python?

Susan Sarandon
Susan Sarandonasal
2024-12-07 10:51:13385semak imbas

What's the Most Efficient Way to Create Lists of Repeated Single Items in Python?

Membuat Senarai Ulangan Item Tunggal

Untuk menjana satu siri senarai yang mengandungi elemen yang sama berulang n kali, terdapat beberapa pendekatan.

Satu kaedah biasa ialah dengan menggunakan senarai pemahaman:

[e for number in range(n)]

Walau bagaimanapun, jika anda mencari pendekatan alternatif, pertimbangkan untuk menggunakan operator pendaraban:

[e] * n

Walaupun kaedah ini berkesan menduplikasi elemen e n kali, ambil perhatian bahawa jika e ialah senarai kosong, anda akan memperoleh senarai dengan n rujukan kepada senarai yang sama, bukannya n kosong berasingan senarai.

Pertimbangan Prestasi

Apabila membandingkan kecekapan masa kaedah yang berbeza, selalunya diandaikan bahawa ulangan adalah lebih baik daripada [e] * n. Walau bagaimanapun, adalah penting untuk menyedari bahawa ulangan tidak serta-merta mencipta senarai. Sebaliknya, ia mengembalikan objek yang membenarkan penciptaan senarai apabila perlu.

Untuk perbandingan prestasi yang lebih tepat:

timeit.timeit('list(itertools.repeat(0, 10))', 'import itertools', number = 1000000)

Pengubahsuaian ini mendedahkan bahawa [e] * n ialah penyelesaian yang lebih cekap untuk menjana senarai sebenar. Walau bagaimanapun, jika elemen yang dijana secara malas diingini, ulangi kekal sebagai pilihan yang berdaya maju.

Atas ialah kandungan terperinci Apakah Cara Paling Cekap untuk Mencipta Senarai Item Tunggal Berulang dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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