用python洗牌数组最简单的方法是什么?


当前回答

我不知道我使用了random。shuffle(),但它返回'None'给我,所以我写了这个,可能对别人有帮助

def shuffle(arr):
    for n in range(len(arr) - 1):
        rnd = random.randint(0, (len(arr) - 1))
        val1 = arr[rnd]
        val2 = arr[rnd - 1]

        arr[rnd - 1] = val1
        arr[rnd] = val2

    return arr

其他回答

import random
random.shuffle(array)

你可以用随机键对数组排序

sorted(array, key = lambda x: random.random())

键只读取一次,所以在排序期间比较项目仍然有效。

但看起来random.shuffle(array)会更快,因为它是用C写的

顺便说一下,这是O(Nlog(N)

除了前面的回复,我想介绍另一个功能。

numpy。random。shuffle和random。进行原地洗牌。但是,如果你想返回一个打乱的数组,可以使用numpy.random.permutation函数。

我不知道我使用了random。shuffle(),但它返回'None'给我,所以我写了这个,可能对别人有帮助

def shuffle(arr):
    for n in range(len(arr) - 1):
        rnd = random.randint(0, (len(arr) - 1))
        val1 = arr[rnd]
        val2 = arr[rnd - 1]

        arr[rnd - 1] = val1
        arr[rnd] = val2

    return arr
import random
random.shuffle(array)