30秒学会 Python 片段 · 2017年7月30日

30秒学会 Python 片段 – shuffle

Randomizes the order of the values of an list, returning a new list.

Uses the Fisher-Yates algorithm to reorder the elements of the list.

random.shuffle provides similar functionality to this snippet.

代码实现

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]