我最近参加了一个编程比赛,我能够及时回答七道题中的六道题。最后一个问题是:“从用户那里取一个数字,用给定数字的幂做一个棋盘,放置尽可能多的皇后,并以某种方式排列皇后,使它们不会在水平、垂直方向上相互威胁和对角线。” 因此,例如,如果用户输入4 ,那么4x4 (16)棋盘中将有4 个皇后。好吧,对于垂直和水平部分,我能够检查它们是否在同一列中,对于对角线部分,我使用了非常糟糕的 while 循环组合,然后将国际象棋游戏中的所有保留位置添加到列表中。问题是我使用随机生成索引的模块,然后检查它们是否在保留数字中,然后再试一次,直到它不存在,所以发生的情况是这个国际象棋游戏只有少数组合,如果开始索引错误,程序会变得漂亮永远停留在while循环中。我曾想过从最后一行到第一行,但即便如此,我仍在使用随机索引。如何让程序计算皇后的位置,而不是随机输入一个数字并查看它是否有效?我的代码:(如果我的代码有其他问题,请指出):
import random
# in the program you had to put '1' as the position of the queens and put '0' as the empty places on the board
# and also, if the user entered a number less than 4 the combination would not have been possible
num = int(input("Enter number: "))
if num >= 4:
arr = [[0 for _ in range(num)] for _ in range(num)]
reserved_num = []
oblique = []
for i in range(num):
j = random.randint(0, num - 1)
while [i, j] in reserved_num:
j = random.randint(0, num - 1)
arr[i][j] = 1
for rows in range(num):
reserved_num.append([rows, j])
if i < num-1:
inc = 0
if j == num-1:
while j-inc > 0 and i+inc < num-1:
inc += 1
oblique.append([i+inc, j-inc])
else:
inc = 0
elif j == 0:
while j+inc < num-1 and i+inc < num-1:
inc+= 1
oblique.append([i+inc, j+inc])
else:
inc = 0
else:
while j+inc < num-1 and i+inc < num-1:
inc+= 1
oblique.append([i+inc, j+inc])
else:
inc = 0
while j-inc > 0 and i+inc < num-1:
inc += 1
oblique.append([i+inc, j-inc])
else:
inc = 0
for res in oblique:
reserved_num.append(res)
for items in arr:
print(items)
else:
print("Not Possible! ")