列表如何用python3代码完成排序?

列表如何用python3代码完成排序?,第1张

列表如何用python3代码完成排序

我们对于列表的抓取已经有所了解,不过光会从列表中获取元素这还远远不够。假设列表元素的顺序是随机的,这时候我们想要获取元素,还是先对列表进行排序比较好。相信重新排好顺序的列表,对于我们的使用和接下来进行其它的代码 *** 作都能简便不少,这里我们要使用shuffle()函数来帮助我们完成,下面是一些shuffle()函数对列表排序的使用。


shuffle()函数是将列表的所有元素随机排序。

有时候我们的任务中会使用到随机sample一个数据集的某些数,比如一个文本中,有10行,我们需要随机选取前5个。

那么我们就可以采取shuffle()函数,然后list中放入1-10个行号,利用shuffle()函数之后,序号就打乱了。

这个时候,我们选取前5个元素即可。就起到了随机打乱的结果了。


代码:

# -*- coding: UTF-8 -*-
#代码功能是测试一下shuffle()函数
import random
number = []
for index in range(1,11):
    number.append(index)
 
random.shuffle(number)
for index in range(5):
print number[index]

 

通过 Fisher-Yates 算法对新列表进行排序,该算法会打乱列表元素的顺序:

from copy import deepcopy
from random import randint
 
def shuffle(lst):
    temp_lst = deepcopy(lst)
    m = len(temp_lst)
    while (m):
        m -= 1
        i = randint(0, m)
        temp_lst[m], temp_lst[i] = temp_lst[i], temp_lst[m]
    return temp_lst
 
 
foo = [1,2,3]
shuffle(foo) # [2,3,1] , foo = [1,2,3]


以上就是用shuffle()函数对列表元素排序的一些 *** 作方法,之后有遇到对列表排序的 *** 作,都可以优先考虑下小编的这种方法,说不定就能轻松解决了呢。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/3014018.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-28
下一篇 2022-09-28

发表评论

登录后才能评论

评论列表(0条)

保存