日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

冒泡排序python例题_零基础学python 15 经典算法:冒泡排序法(课后习题答案)...

發布時間:2023/12/19 python 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 冒泡排序python例题_零基础学python 15 经典算法:冒泡排序法(课后习题答案)... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這節課我們對于冒泡排序法的課后習題進行一下解答:

回顧一下我們的題目:

上節課我們學習的冒泡排序法,是讓我們的list從小到大進行排列,這次我們的任務是,請對冒泡排序法進行一定的修改,加一個參數,讓它能夠按照我們的定義需要進行從大到小或者從小到大的排序。返回這個排序后的list。

下面是我們需要實現的一些例子,從例子中你可以了解到第二個參數的一些定義規則。假定輸入的參數沒有錯誤等問題。

函數調用命令

返回值

bubbleSort([37,87,12,3,0],1)

[0, 3, 12, 37, 87]

bubbleSort([7,8,123,33,1],2)

[123, 33, 8, 7, 1]

bubbleSort([3411,5,32,57,521],1)

[5, 32, 57, 521, 3411]

解析:

這道題很神奇讓我們比之前多加了一個參數,使得我們可以通過參數來控制返回的list是從大到小還是從小到大排列。我們可以從要實現的例子中發現絲絲端倪,那就是第二個參數如果是1的時候,返回的list就會從小到大排列,如果是2,就會從大到小排列,明白這一點之后,新定義的參數就很容易弄出來了。

我們需要對新定義的參數進行判斷,是1則在判斷前一個數大于后一個數的時候才交換位置,是2則在判斷前一個數小于后一個數的時候才進行交換。

以下是最后的參考代碼:

def bubbleSort(nums, k):

# 請修改代碼成題目要求的樣子

for i in range(len(nums)-1): # 這個循環負責設置冒泡排序進行的次數

for j in range(len(nums)-i-1): # j為列表下標

if k == 1:

if nums[j] > nums[j+1]:

nums[j], nums[j+1] = nums[j+1], nums[j]

elif k == 2:

if nums[j] < nums[j+1]:

nums[j], nums[j+1] = nums[j+1], nums[j]

return nums

# 測試代碼

print("testing bubbleSort for ([37,87,12,3,0],1) result:" + str(bubbleSort([37,87,12,3,0],1)))

print("testing bubbleSort for ([7,8,123,33,1],2) result:" + str(bubbleSort([7,8,123,33,1],2)))

print("testing bubbleSort for ([3411,5,32,57,521],1) result:" + str(bubbleSort([3411,5,32,57,521],1)))

以下是我們的視頻教程:

在線觀看:

高清源文件下載:

內容已經隱藏,請注冊為本站會員后查看

感謝大家的收看,我們下期再見!

總結

以上是生活随笔為你收集整理的冒泡排序python例题_零基础学python 15 经典算法:冒泡排序法(课后习题答案)...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。