我正在编写一个程序,可以随机播放给定的序列(列表l),m次。我的函数接受列表 l 和数字 m 作为输入,但 Ive 为一次洗牌定义了洗牌本身,然后使用 for 循环来执行 m 次。但是,现在 for 循环不采用用户分配的值 m。
我是Python菜鸟,所以我可能错过了一件简单的事情。我尝试使用全局 m 在我的函数中(重新)定义 m,但要么我不知道该怎么做,要么它似乎不起作用。
def riffle_shuffle(l, global m):
#global m goes here?
r = np.random.binomial(len(l),0.5)
sd1 = l[:r]
d2 = l[r:]
fl = []
c = [sd2,sd1]
l2 = sd2+sd1
for i in range(1,len(l) + 1):
x = [sd2,sd1]
y = [(len(sd2))/(len(l) - i+1),(len(sd1))/(len(l) - i+1)]
a = choices(x,y)
a1 = a[0][0]
fl.append(a1)
#Deck Split is c
#Sub decks are',c
#Probabilities are',y
#Deck chosen is',a
#fl
if a1 in sd1:
sd1.remove(a1)
elif a1 in sd2:
sd2.remove(a1)
return fl,m
for j in range(1,m+1):
fl = riffle_shuffle(fl)
return fl
我收到错误,说m未定义,语法无效,以下错误消息。我不知道最后一个是什么意思。
"相比之下,超过了最大递归深度">
非常感谢任何帮助,谢谢!
编辑:我错过了我在描述中提到的for循环。现在对不起。
所以...你想要的方法可以做 riffle shuffle m 次,对吧?
您的代码存在一些问题:
首先,return
在函数之外。
其次,你在函数中调用你的函数,而不破坏条件:所以函数将调用函数,这将一次又一次地调用函数,依此类推,直到发生错误。那是maximum recursion depth exceeded in comparison
.
第三,你使用了这样的np.random.choice
:np.random.choice(x, p=y)
。否则,python不知道y是概率,它会将其解释为第二个参数:输出的大小。所以这里会发生错误。
这可能是您要编写的代码:
import numpy as np
def riffle_shuffle(l, m):
if m == 0:
return l
else:
fl = []
r = np.random.binomial(len(l), 0.5)
sd1 = l[:r]
sd2 = l[r:]
c = [sd2,sd1]
l2 = sd2+sd1
for i in range(1,len(l) + 1):
x = [sd2,sd1]
y = [(len(sd2))/(len(l) - i+1), (len(sd1))/(len(l) - i+1)]
a = np.random.choice(2, p=y)
a = x[a]
a1 = a[0]
fl.append(a1)
#Deck Split is c
#Sub decks are',c
#Probabilities are',y
#Deck chosen is',a
#fl
if a1 in sd1:
sd1.remove(a1)
elif a1 in sd2:
sd2.remove(a1)
fl = riffle_shuffle(fl, m - 1)
return fl
a = riffle_shuffle([1, 2, 3, 4, 5, 6, 7, 8], 3)
print(a)
#output : [5, 6, 1, 7, 4, 8, 2, 3] (can be changed)
正如你所做的那样,我"递归地"调用函数 - 在函数中调用函数 - 带有中断条件。
这样,您就不必使用全局变量 - 在大多数情况下,使用全局变量并不是一个好主意。
而且,关于您的问题(如何使用户提供的值成为全局变量),您可以做这样的事情。
a = 0
def foo(m):
global a
a = m
#and your code here...