關於Python中sort函式賦值的問題

2021-06-28 17:17:26 字數 1391 閱讀 6060

1樓:匿名使用者

python中的sort()方法用於陣列排序,本文以例項形式對此加以詳細說明:

一、基本形式

列表有自己的sort方法,其對列表進行原址排序,既然是原址排序,那顯然元組不可能擁有這種方法,因為元組是不可修改的。

123x = [4, 6, 2, 1, 7, 9]x.sort()print x # [1, 2, 4, 6, 7, 9]

如果需要一個排序好的副本,同時保持原有列表不變,怎麼實現呢

12345

x =[4, 6, 2, 1, 7, 9]y = x[ : ]y.sort()print y #[1, 2, 4, 6, 7, 9]print x #[4, 6, 2, 1, 7, 9]

注意:y = x[:] 通過分片操作將列表x的元素全部拷貝給y,如果簡單的把x賦值給y:y = x,y和x還是指向同一個列表,並沒有產生新的副本。

另一種獲取已排序的列表副本的方法是使用sorted函式:

1234

x =[4, 6, 2, 1, 7, 9]y = sorted(x)print y #[1, 2, 4, 6, 7, 9]print x #[4, 6, 2, 1, 7, 9]

sorted返回一個有序的副本,並且型別總是列表,如下:

1print sorted('python') #['p', 'h', 'n', 'o', 't', 'y']

二、自定義比較函式

可以定義自己的比較函式,然後通過引數傳遞給sort方法:

12345678910111213

def comp(x, y):if x < y:return 1elif x > y:

return -1else:return 0 nums = [3, 2, 8 ,0 , 1]nums.sort(comp)print nums # 降序排序[8, 3, 2, 1, 0]nums.

sort(cmp) # 呼叫內建函式cmp ,升序排序print nums # 降序排序[0, 1, 2, 3, 8]

三、可選引數

sort方法還有兩個可選引數:key和reverse

1、key在使用時必須提供一個排序過程總呼叫的函式:

123x = ['mmm', 'mm', 'mm', 'm' ]x.sort(key = len)print x # ['m', 'mm', 'mm', 'mmm']

2、reverse實現降序排序,需要提供一個布林值:

123y = [3, 2, 8 ,0 , 1]y.sort(reverse = true)print y #[8, 3, 2, 1, 0]

2樓:匿名使用者

python 中 sort()方法直接對列表的物件進行排序,沒有返回值

關於python呼叫函式問題,python中關於函式呼叫的問題提

蛋疼的公司網路bai,看不到 du首先確認下是否import成功zhi了dao比如你importknn那你呼叫的時候專要寫knn.classify0不然就寫fromknnimport 然後 屬就可以直接呼叫了 預設你放在同個目錄下 python中關於函式呼叫的問題提 10 def add pram1...

2下列給定程式中,函式sort的功能是用氣泡排序法

其實這就是冒泡 復排序法的函式實制 現,跟普通的冒泡法沒什麼區別的 在函式中,給的引數是陣列名和陣列長度,這也是冒泡法最主要的兩個資料了,給你具體實現一下 void sort int a,int n 對n個數的排序需要n 1趟,每趟需要比較n次,這樣的程式執行效率高。樓上的執行了99趟,每趟99次,...

Python中怎麼用len函式轉換2進位制到10進位制一定要用到len函式,比如輸入

len是求字bai符串長度的函式 是不能du進行進位制轉換器 當然對輸zhi入這種dao二進位制形式的字串版進行轉換成十進位制資料權是可以使用len函式的 因為可以使用它計算字串長度 然後從字串末尾開始進行進位制轉換 如果 不想自己寫的話 支付寶3元我可以代勞 def main a hello c ...