所以,我想要一个函数返回一个列表(l),它有值(0,1,2,3。。。,n),但连续的数字不能相邻。数字的值不能等于它的索引。你知道吗
例如,对于n=4
def main(n)
---code goes here---
return l
print(main(4))
>>>[1, 3, 0, 2]
多谢了
编辑: 到目前为止,我已经写了这么多,但我不确定我是否在正确的轨道上。。。你知道吗
def sameRowColumn(lst):
for i in range(len(lst)):
if i == lst[i]:
return True
def sameDiagonal(lst):
for i in range(len(lst)):
for j in range(len(lst)):
if i != j:
if i + lst[i] == j + lst[j] or i - lst[i] == j - lst[j]:
return True
# def backTrack(lst1, lst2, dist):
# for i in range(len(lst1)-1, (len(lst1)-1)-dist, -1):
# lst2.append(lst1[i])
# lst1.remove(lst1[i])
def queensList(N):
l = []
nums = [i for i in range(N)]
while len(l) != N and len(nums) != 0:
l.append(nums[0])
print(l, nums)
if sameRowColumn(l) or sameDiagonal(l):
l.remove(nums[0])
nums.insert(len(nums), nums.pop(0))
print(l, nums)
else:
nums.remove(nums[0])
print(l, nums)
return l, nums
print(queensList(4))
在这里,它在python3.6中进行了测试
这打印所有奇数,然后反向打印所有偶数,如果最后一个偶数等于索引,则交换n-1和n
相关问题 更多 >
编程相关推荐