演算法(三)二元選擇排序

來源:互聯網
上載者:User

標籤:二元選擇排序

二元選擇排序

在簡單選擇排序的基礎上,一輪中同時比較出最大值與最小值


lst1 = [    [1, 8, 9, 5, 6, 7, 4, 3, 2],    [9, 8, 7, 6, 5, 4, 3, 2, 1],    [1, 2, 3, 4, 5, 6, 7, 8, 9],    [1, 1, 1, 1, 3, 1, 1, 1, 2]]nums = lst1[0]length = len(nums)print(nums)count_iter = 0  #迭代計數器count_swap = 0  #發生交換的次數計數器for i in range(length//2):    maxindex = i    minindex = -i -1    minorigin = minindex    for j in range(i + 1, length - i): #每次左右都要少比較一個        count_iter += 1        if nums[j] > nums[maxindex]:            maxindex = j        if nums[-j - 1] < nums[minindex]:            minindex = -j - 1    #print(maxindex, minindex)    if maxindex != i:        nums[maxindex], nums[i] = nums[i], nums[maxindex]        count_swap += 1        if i == minindex or i == length + minindex:            minindex = maxindex    if minorigin != minindex:        nums[minorigin], nums[minindex] = nums[minindex], nums[minorigin]        count_swap += 1print(nums, count_iter, count_swap)


輸出結果:

[1, 8, 9, 5, 6, 7, 4, 3, 2][9, 8, 7, 6, 5, 4, 3, 2, 1] 20 6


演算法(三)二元選擇排序

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.