关于越界问题,根据输入数据的不同,会有三种错误

问题遇到的现象和发生背景

运行前没有错误,但是运行后会分别出现三种错误

问题相关代码,请勿粘贴截图
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,个人感觉在列表中从后向前删除,前面的索引位置不会改变,应该不会出现越界的情况

img

我想要达到的结果

img

1.你的图都糊了,根本看不清题目,从你乱七八糟的代码里也根本分析不出来你到底想干什么,也没个注释
2.该用for就用for,来控制循环次数,不要全部都用while
3.既然你用python,思维不要老停留在c语言上,该用集合操作就用集合操作,比如筛法求质数,你用一个全集减去一个偶数集,要比你一个一个删快的多,而且代码简练,也不容易出错