Python中l(wèi)ist打亂順序后復(fù)位的實(shí)現(xiàn)示例
1.list數(shù)組打亂順序后復(fù)位
1.1 首先創(chuàng)建一個(gè)數(shù)組
創(chuàng)建original_array數(shù)組[5, 2, 8, 1, 7]
original_array = [5, 2, 8, 1, 7]
1.2 獲取原數(shù)組位置索引
采用字典positions記錄數(shù)組中每個(gè)數(shù)的位置,字典key值代表值,字典value值代表數(shù)組位置索引。original_array數(shù)組 值 與 位置索引 5->0,2->1,8->2,1->3,7->4存入到positions字典。
positions = {value: index for index, value in enumerate(original_array)} 1.3 打亂數(shù)組
shuffled_array = random.sample(original_array, len(original_array))
1.4 數(shù)組復(fù)位
打亂順序后的數(shù)組shuffled_array的值帶入到字典key中進(jìn)行排序,就是將其原先的位置索引進(jìn)行排序然后得到原先數(shù)組值。
sorted_array = sorted(shuffled_array, key=lambda x: positions[x])
完整的代碼如下:
import random
# 原始數(shù)組
original_array = [5, 2, 8, 1, 7]
# 記錄每個(gè)元素在原始數(shù)組中的位置
positions = {value: index for index, value in enumerate(original_array)}
# 打散數(shù)組
shuffled_array = random.sample(original_array, len(original_array))
# 打印打散后的數(shù)組
print("打散后的數(shù)組:", shuffled_array)
# 按照原始位置信息對(duì)打散后的數(shù)組進(jìn)行排序
sorted_array = sorted(shuffled_array, key=lambda x: positions[x])
# 打印恢復(fù)后的數(shù)組
print("恢復(fù)后的數(shù)組:", sorted_array)2.list 排序后 進(jìn)行階乘后復(fù)位
import math
list1 = [5, 8, 1, 7, 4, 6, 2, 9, 3]
# 對(duì)列表進(jìn)行排序并獲取排序后的索引
sorted_indexes = sorted(range(len(list1)), key=lambda k: list1[k])
# 這個(gè)是這樣理解的 首先是0 - 8 ,然后依次帶入,key=lambda k: list1[k]#
# 也即是[5, 8, 1, 7, 4, 6, 2, 9, 3],然后發(fā)現(xiàn) 2帶進(jìn)去的數(shù)最小,所以 2排在前面。依次6
print(sorted_indexes)
sorted_list = [list1[i] for i in sorted_indexes]
# 對(duì)排序后的每個(gè)元素進(jìn)行階乘運(yùn)算
factorial_result = [math.factorial(x) for x in sorted_list]
# 按照原始順序恢復(fù)排序后的結(jié)果
restored_list = [factorial_result[sorted_indexes.index(i)] for i in range(len(list1))] # 必須使用index 的原因是 確定i存在的順序
# 輸出結(jié)果
print("原始數(shù)組:", list1)
print("排序后的數(shù)組:", sorted_list)
print("階乘后的數(shù)組:", factorial_result)
print("按照原始順序恢復(fù)的數(shù)組:", restored_list)3.list 進(jìn)行隨機(jī)亂序后 進(jìn)行階乘后復(fù)位
import math
import random
list1 = [5, 8, 1, 7, 4, 6, 2, 9, 3]
# 打亂順序
shuffled_indexes = list(range(len(list1)))
print(shuffled_indexes)
random.shuffle(shuffled_indexes)
shuffled_list = [list1[i] for i in shuffled_indexes]
print("打亂順序后的列表", shuffled_indexes)
# 對(duì)打亂順序后的每個(gè)元素進(jìn)行階乘運(yùn)算
factorial_result = [math.factorial(x) for x in shuffled_list]
# 按照原始順序恢復(fù)排序后的結(jié)果
restored_list = [factorial_result[shuffled_indexes.index(i)] for i in range(len(list1))]
# 輸出結(jié)果
print("原始數(shù)組:", list1)
print("打亂順序后的數(shù)組:", shuffled_list)
print("階乘后的數(shù)組:", factorial_result)
print("按照原始順序恢復(fù)的數(shù)組:", restored_list)
4. 利用pandas進(jìn)行復(fù)位
import pandas as pd from natsort import natsorted # 讀取Excel文件 file_path = 'C:\\Users\\GP\\Desktop\\work\\低周應(yīng)力應(yīng)變\\1SUO-6852\\尺寸.xlsx' # 替換成你的Excel文件路徑 df = pd.read_excel(file_path) # 獲取第一列的數(shù)據(jù) columnData0 = df.iloc[:,0].tolist() # 使用natsort進(jìn)行自然排序,得到排序后的索引順序 sort_index = natsorted(range(len(columnData0)),key= lambda x:columnData0[x] ) # columnData0 按照sort_index的順序進(jìn)行排序 columnData0 = [columnData0[i] for i in sort_index] df_sort=df.reindex(sort_index) # df_sort1=df.iloc[sort_index] print(df_sort) # mark 現(xiàn)在是已經(jīng)將程序上的東西對(duì)上來了 # 將整個(gè)DataFrame恢復(fù)原有的排序 df_sort = df_sort.sort_index() print(df_sort)
到此這篇關(guān)于Python中l(wèi)ist打亂順序后復(fù)位的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python list打亂順序后復(fù)位內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python dataframe實(shí)現(xiàn)統(tǒng)計(jì)行列中零值的個(gè)數(shù)
這篇文章主要介紹了python dataframe實(shí)現(xiàn)統(tǒng)計(jì)行列中零值的個(gè)數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
python實(shí)現(xiàn)打開手機(jī)app并點(diǎn)擊操作
這篇文章主要介紹了python實(shí)現(xiàn)打開手機(jī)app并點(diǎn)擊操作,本文分為兩部分一部分是打開應(yīng)用,第二部分是調(diào)式手機(jī)連接電腦,需要的朋友可以參考下2022-04-04
Python入門經(jīng)典題目實(shí)戰(zhàn)應(yīng)用指南
Python作為一門易學(xué)且功能強(qiáng)大的編程語言,是初學(xué)者入門編程的理想選擇,通過解決實(shí)際問題,我們可以更好地理解和掌握Python的基礎(chǔ)知識(shí),這篇文章主要介紹了Python入門經(jīng)典題目實(shí)戰(zhàn)應(yīng)用的相關(guān)資料,需要的朋友可以參考下2025-10-10
python基礎(chǔ)教程之實(shí)現(xiàn)石頭剪刀布游戲示例
使用PYTHON設(shè)計(jì)一個(gè)"石頭,剪子,布"游戲,有時(shí)又叫"Rochambeau",下面是實(shí)現(xiàn)方法,需要的朋友可以參考下2014-02-02
Python獲取服務(wù)器信息的最簡單實(shí)現(xiàn)方法
這篇文章主要介紹了Python獲取服務(wù)器信息的最簡單實(shí)現(xiàn)方法,涉及Python中urllib2庫的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
Python實(shí)現(xiàn)在多個(gè)Word文檔中一鍵搜索
在日常工作和學(xué)習(xí)中,我們經(jīng)常需要在大量word文檔中查找特定的文本,下面小編就來和大家介紹一下如何使用Python腳本在同一文件夾下的所有word文件中搜索指定的文本吧2025-07-07

