Rumah >pembangunan bahagian belakang >Tutorial Python >Penjelasan grafik terperinci algoritma jenis gelembung Python

Penjelasan grafik terperinci algoritma jenis gelembung Python

WBOY
WBOYke hadapan
2022-06-06 19:21:083512semak imbas

Artikel ini membawakan anda pengetahuan yang berkaitan tentang python Ia terutamanya memperkenalkan isu berkaitan tentang pengisihan gelembung, termasuk penerangan algoritma, analisis, pelaksanaan kod, dsb. Berikut ialah Mari kita lihat, harap ia membantu semua orang. .

Penjelasan grafik terperinci algoritma jenis gelembung Python

Pembelajaran yang disyorkan: tutorial video python

1. Penerangan algoritma

Isih Buih (Isih Buih) ialah algoritma pengisihan yang mudah. Ia berulang kali berulang melalui tatasusunan untuk diisih, membandingkan dua elemen pada satu masa dan menukarnya jika ia berada dalam susunan yang salah. Kerja melintasi tatasusunan diulang sehingga tiada lagi pertukaran diperlukan, yang bermaksud tatasusunan telah diisih. Nama algoritma ini berasal dari fakta bahawa elemen yang lebih kecil akan perlahan-lahan "terapung" ke bahagian atas tatasusunan melalui pertukaran.

2. Analisis algoritma

1. Jika yang pertama lebih besar daripada yang kedua (dalam tertib menaik), tukar kedua-duanya.

2. Lakukan perkara yang sama untuk setiap pasangan elemen bersebelahan, daripada pasangan pertama di awal hingga pasangan terakhir di penghujung. Selepas langkah ini selesai, elemen terakhir akan menjadi nombor terbesar.

3. Ulang langkah di atas untuk semua elemen kecuali yang terakhir.

4 Teruskan mengulangi langkah di atas untuk semakin sedikit elemen setiap kali sehingga tiada pasangan nombor yang tinggal. Perlu membandingkan.
Penjelasan grafik terperinci algoritma jenis gelembung Python
Kemudian kita perlu melakukan proses menggelegak n-1, dan bilangan perbandingan yang sepadan untuk setiap kali adalah seperti yang ditunjukkan di bawah:
Penjelasan grafik terperinci algoritma jenis gelembung Python

3. Paparan GIF

Sekarang kita memahami proses berjalan, mari kita lihat pelaksanaan GIF:

Penjelasan grafik terperinci algoritma jenis gelembung Python

4 Pelaksanaan kod

Kami mengisih senarai tidak tertib berikut
Penjelasan grafik terperinci algoritma jenis gelembung Python

Pelaksanaan kod:

import timepop_list = [19, 14, 10, 4, 15, 26, 20, 96]print("没排序前的列表为:", pop_list)# 记录开始时间start = time.time()# 外层循环控制轮数for i in range(len(pop_list) - 1):
    # 内层循环控制比较次数
    for j in range(len(pop_list) - i - 1):
        # 如果前一个数字比后一个数字大,就交换位置
        if pop_list[j] > pop_list[j + 1]:
            # python特有交换位置方式
            pop_list[j], pop_list[j + 1] = pop_list[j + 1], pop_list[j]print("排序好的列表为:", pop_list)# 记录结束时间end = time.time()print("算法总耗时:", end - start)

Hasil berjalan:

Penjelasan grafik terperinci algoritma jenis gelembung Python

5 Naik taraf algoritma

Bilangan pembolehubah ditakrifkan dalam gelung. , jika kiraan tidak berubah selepas gelung pertama, ini bermakna input adalah urutan tertib Pada masa ini, kami terus kembali untuk keluar dari gelung Kerumitan masa pada masa ini ialah O(n)

Kod pelaksanaan:

import timedef bubble_sort(pop_list):
    for j in range(len(pop_list) - 1, 0, -1):
        count = 0
        for i in range(0, j):
            if pop_list[i] > pop_list[i + 1]:
                pop_list[i], pop_list[i + 1] = pop_list[i + 1], pop_list[i]
                count += 1
        if count == 0:
            returnpop_list = [19, 14, 10, 4, 15, 26, 20, 96]print("没排序前的列表为:", pop_list)# 记录开始时间start = time.time()bubble_sort(pop_list)print("排序好的列表为:", pop_list)# 记录结束时间end = time.time()print("算法总耗时:", end - start)

Hasil jalankan:
Penjelasan grafik terperinci algoritma jenis gelembung Python

6. Analisis kerumitan masa

  • Kerumitan masa optimum: O(n) (Menunjukkan bahawa selepas merentasi, didapati tiada unsur yang boleh ditukar, dan pengisihan tamat.)
  • Kerumitan masa paling teruk: O(n^2)
  • Kestabilan: Stabil



  • Apabila jumlah bilangan elemen tatasusunan ialah N, jumlah bilangan perbandingan yang diperlukan ialah:
  • (N-1) (N-2) (N-3) ...1=N*(N-1)/2

    Algoritma membuat kira-kira
  • perbandingan. Oleh kerana data ditukar hanya apabila elemen sebelumnya lebih besar daripada elemen berikut, bilangan swap adalah kurang daripada bilangan perbandingan. Jika data adalah rawak dan kira-kira separuh daripada data perlu ditukar, bilangan pertukaran ialah
  • (tetapi dalam kes yang paling teruk, apabila data awal dalam susunan terbalik, setiap perbandingan memerlukan pertukaran). N^2/2N^2/4

    Bilangan pertukaran dan operasi perbandingan adalah berkadar dengan N^2 Memandangkan dalam tatatanda O besar, pemalar diabaikan, pengisihan gelembung adalah kompleks masa ijazah ialah
  • .
  • O(N^2)
  • Pembelajaran yang disyorkan:
tutorial video python

Atas ialah kandungan terperinci Penjelasan grafik terperinci algoritma jenis gelembung Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:csdn.net. Jika ada pelanggaran, sila hubungi admin@php.cn Padam