使用 for 循环将元素导入列表
Import elements to a list with for loop
我对 Python 比较陌生,我正在尝试将随机数 (new_bandit) 添加到列表 new_bandit_probs if i == x。但是如果我打印 new_bandit_probs 列表,我只会得到一个空列表。有人可以帮我吗?
import numpy as np
bandit_probs = [0.1, 0.4, 0.9]
N_bandits = len(bandit_probs)
N_experiments = 1
N_episodes = 100
new_bandit = np.random.random ()
x = np.random.randint(0, N_episodes)
new_bandit_probs = []
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x, new_bandit_probs):
for i in range(N_episodes):
if i == x:
new_bandit_probs.append(bandit_probs, new_bandit)
return(new_bandit_probs)
您的 return 在 for 循环中。在 i 从 0 递增到 1 之前 returns。如果 x!=0
那么它将 return 空列表。
将其移出 for 循环:
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x, new_bandit_probs):
for i in range(N_episodes):
if i == x:
new_bandit_probs.append(bandit_probs, new_bandit)
return(new_bandit_probs)
您的代码无法正常工作,因为您的 return
是在 for
循环的第一次迭代后立即设置的。
此外,您的 new_bandit_probs
是空的,因此在第一次迭代后停止,return 一个空列表给出...一个空列表。下面进行一些修改:
import numpy as np
bandit_probs = [0.1, 0.4, 0.9]
N_bandits = len(bandit_probs)
N_experiments = 1
N_episodes = 100
new_bandit = np.random.random ()
x = np.random.randint(0, N_episodes)
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x):
for i in range(N_episodes):
if i == x:
bandit_probs.append(new_bandit)
return bandit_probs
print (update_bandit_probs (bandit_probs, N_episodes, new_bandit, x))
输出:
[0.1, 0.4, 0.9, 0.4026139866070344]
您也可以在一行中执行此操作:
def update_bandit_probs(v, n, c, x):
return v+[c for i in range(n) if x == i]
print (update_bandit_probs(bandit_probs, N_episodes, new_bandit, x))
我对 Python 比较陌生,我正在尝试将随机数 (new_bandit) 添加到列表 new_bandit_probs if i == x。但是如果我打印 new_bandit_probs 列表,我只会得到一个空列表。有人可以帮我吗?
import numpy as np
bandit_probs = [0.1, 0.4, 0.9]
N_bandits = len(bandit_probs)
N_experiments = 1
N_episodes = 100
new_bandit = np.random.random ()
x = np.random.randint(0, N_episodes)
new_bandit_probs = []
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x, new_bandit_probs):
for i in range(N_episodes):
if i == x:
new_bandit_probs.append(bandit_probs, new_bandit)
return(new_bandit_probs)
您的 return 在 for 循环中。在 i 从 0 递增到 1 之前 returns。如果 x!=0
那么它将 return 空列表。
将其移出 for 循环:
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x, new_bandit_probs):
for i in range(N_episodes):
if i == x:
new_bandit_probs.append(bandit_probs, new_bandit)
return(new_bandit_probs)
您的代码无法正常工作,因为您的 return
是在 for
循环的第一次迭代后立即设置的。
此外,您的 new_bandit_probs
是空的,因此在第一次迭代后停止,return 一个空列表给出...一个空列表。下面进行一些修改:
import numpy as np
bandit_probs = [0.1, 0.4, 0.9]
N_bandits = len(bandit_probs)
N_experiments = 1
N_episodes = 100
new_bandit = np.random.random ()
x = np.random.randint(0, N_episodes)
def update_bandit_probs (bandit_probs, N_episodes, new_bandit, x):
for i in range(N_episodes):
if i == x:
bandit_probs.append(new_bandit)
return bandit_probs
print (update_bandit_probs (bandit_probs, N_episodes, new_bandit, x))
输出:
[0.1, 0.4, 0.9, 0.4026139866070344]
您也可以在一行中执行此操作:
def update_bandit_probs(v, n, c, x):
return v+[c for i in range(n) if x == i]
print (update_bandit_probs(bandit_probs, N_episodes, new_bandit, x))