zoukankan      html  css  js  c++  java
  • Python 如何随机打乱列表(List)排序

    场景:

    现在有一个list:[1,2,3,4,5,6],我需要把这个list在输出的时候,是以一种随机打乱的形式输出。

    专业点的术语:将一个容器中的数据每次随机逐个遍历一遍。

    注意:不是生成一个随机的list集。

    环境:

    Python 3.6

    解决方案:

    方案一:

    有人可能会通过Random内置函数,来间接实现想要的结果。但是这种方式,太原始,也不够优雅,而且有种重复造轮子的嫌疑。这里我就不贴我自己通过random实现的效果了。

    方案二:

    Random中有一个random.shuffle()方法提供了完美的解决方案。代码如下:

    x = [1,2,3,4,5,6]
    random.shuffle(x)
    print(x)
    

    输出结果:

    第一次输出内容:[6, 5, 1, 3, 2, 4]
    第二次输出内容:[6, 1, 3, 5, 2, 4]
    第三次输出内容:[5, 3, 1, 2, 4, 6]
    

    从结果我们可以看出,输出是完全随机的,代码量就两行,不需要random,不需要for循环。

    源码解读:

    此部分原文链接:Python中打乱列表顺序 random.shuffle()的使用方法

    def shuffle(self, x, random=None):
        """Shuffle list x in place, and return None.
        原位打乱列表,不生成新的列表。
    
        Optional argument random is a 0-argument
        function returning a random float in [0.0, 1.0); 
        if it is the default None, 
        the standard random.random will be used.
    	可选参数random是一个从0到参数的函数,返回[0.0,1.0)中的随机浮点;
    	如果random是缺省值None,则将使用标准的random.random()。
        """
    
        if random is None:
            randbelow = self._randbelow
            for i in reversed(range(1, len(x))):
                # pick an element in x[:i+1] with which to exchange x[i]
                j = randbelow(i + 1)
                x[i], x[j] = x[j], x[i]
        else:
            _int = int
            for i in reversed(range(1, len(x))):
                # pick an element in x[:i+1] with which to exchange x[i]
                j = _int(random() * (i + 1))
                x[i], x[j] = x[j], x[i]
    
    

    注意 :
    从代码的注释,我们看到random.shuffle()是对原list做修改,如果需要保留原list,请注意这个细节。
    本文首发于BigYoung小站

  • 相关阅读:
    JAVA消息对话框
    stringbuffer capacity()的疑问
    JAVA确认对话框
    c/c++实现获取NOD32升级账号密码
    复制构造函数(拷贝构造函数)
    使用VC将sqlite3.def转化为sqlite3.lib
    Windows下安装OpenSSL
    java中io与nio的使用
    使用 XStream 把 Java 对象序列化为 XML
    使用 XStream 把 Java 对象序列化为 XML
  • 原文地址:https://www.cnblogs.com/bigyoung/p/12932640.html
Copyright © 2011-2022 走看看