首頁 > 後端開發 > Python教學 > 如何用Python實作取得亂序列表排序後的新索引

如何用Python實作取得亂序列表排序後的新索引

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2023-05-09 23:05:28
轉載
1866 人瀏覽過

對一個清單list而言,進行排序是很簡單的。正序排序(從小到大)用

list.sort()
登入後複製

 倒序排序(從大到小)用

list.sort(reverse=True)
登入後複製

但是如果不僅限於得到一個排完序的列表,還希望記錄原本的下標,那麼對於一個numpy.array而言,可以用

np.argsort()
登入後複製

 例如[1,3,2,5,6]

排序後變成[1,2,3,5 ,6]

但是我們想知道排序後的結果對應原本的下標是什麼(答案是[0,2,1,3,4]),就可以用np.argsort()

但是如果就是個簡單的list,想實現這個效果,就可以用

# enumerate(x)会自动构造一个tuple(a,b)
# 其中a是index,b是list里index下标对应的具体的值,后面的x是代表一个虚拟变量,即tuple(a,b)
sorted_list = sorted(enumerate(list), key=lambda x:x[1])  # x[1]是因为在enumerate(a)中,a数值在第1位
result = [x[0] for x in sorted_list]
登入後複製

這樣返回的result就是原本的index

如果要實現標題裡的,更進一步,即要得到一個list排序後的新下標,例如對於[1,5,2,8,3,4],應該得到[0,4,1,5,2,3]

那可以用

# enumerate(x)会自动构造一个tuple(a,b)
# 其中a是index,b是list里index下标对应的具体的值,后面的x是代表一个虚拟变量,即tuple(a,b)
# sorted_list = [(0,1),(2,2),(4,3),(5,4),(1,5),(3,8)]
sorted_list = sorted(enumerate(list), key=lambda x:x[1])  # x[1]是因为在enumerate(a)中,a数值在第1位
for i in range(len(sorted_list)):
    list[sorted_list[i][1]] = i
登入後複製

以上是如何用Python實作取得亂序列表排序後的新索引的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
python - ubuntu16.04 lxml的報錯
來自於 1970-01-01 08:00:00
0
0
0
有辦法在PHP裡寫Python嗎?
來自於 1970-01-01 08:00:00
0
0
0
python scrapy爬蟲錯誤
來自於 1970-01-01 08:00:00
0
0
0
python相關問題求解決,有償
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板