您好,登錄后才能下訂單哦!
這篇文章主要介紹了Python怎么實現獲取亂序列表排序后的新下標的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Python怎么實現獲取亂序列表排序后的新下標文章都會有所收獲,下面我們一起來看看吧。
對一個列表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怎么實現獲取亂序列表排序后的新下標”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Python怎么實現獲取亂序列表排序后的新下標”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。