我有9x9的numpy数组,其中填充了数字[1; 9]。我需要选择随机位置并将该单元格分配为0,直到获得一定的难度值为止。顺便说一句,我的表应该满足某些标准,并且在多个测试中检查了功能。
while current_difficulty > self.difficulty:
i = np.random.randint(0, self.board_size, 1)
j = np.random.randint(0, self.board_size, 1)
if self.unsolved[i, j] != 0 and self.__is_solvable():
self.unsolved[i, j] = 0
current_difficulty -= 1
我需要的是获得不会随时间重复的随机值对(i和j)。是否可以使用任何功能或可以实现的方法? 预先谢谢你。
答案 0 :(得分:1)
基本思想:生成所有唯一的对(希望棋盘不是太大),然后随机播放:
from itertools import product
# ...
indexes = list(product(np.arange(self.board_size), np.arange(self.board_size)))
np.random.shuffle(indexes) # unique indexes in random order
for i, j in indexes:
if some_check(i, j):
break