运行前没有错误,但是运行后会分别出现三种错误
print('输入n:')
n: int = int(input())
print('输入k:')
k: int = int(input())
i: int = 1
l: int = 0
u: int = 0
a = list()
b = list()
c = list()
while i <= n: # 初始化 队
a.append(i)
i += 1
def step1():
global n, b, l
j = 1
q = 0
v = n
while v > (k - 2):
while j <= n:
j += 1
if j % k == 0:
q += 1 # 第一回合减去元素的个数
v -= 1
b.append(j + 1)
l = len(b) - 1
while l >= 0:
del a[b[l]]
l -= 1
n = n - q
b = []
return n
def step2():
global n, u, c
g = 1
p = 0
x = n
while x > (k - 2):
while g <= n:
g += 1
if g % k == 0:
p += 1 # 第二回合减去元素的个数
x -= 1
c.append(n + 1 - g)
u = len(c) - 1
while u >= 0:
del a[c[u]]
u -= 1
n = n - p
c = []
return n
def main():
while n > (k - 2):
step1()
step2()
print('输出')
for x in a:
print(x, end=' ')
if __name__ == '__main__':
main()
这个代码运行的结果有三种:(依据输入的n和k值的大小关系,会分别出现三种结果)1.死循环,输入k的值后,无法结束输入过程。2.当k>n时,可以正常输出。3.报错,IndexError: list assignment index out of range,个人感觉在列表中从后向前删除,前面的索引位置不会改变,应该不会出现越界的情况
1.你的图都糊了,根本看不清题目,从你乱七八糟的代码里也根本分析不出来你到底想干什么,也没个注释
2.该用for就用for,来控制循环次数,不要全部都用while
3.既然你用python,思维不要老停留在c语言上,该用集合操作就用集合操作,比如筛法求质数,你用一个全集减去一个偶数集,要比你一个一个删快的多,而且代码简练,也不容易出错