运气最佳游戏: 一群人排成一圈,按“1,2,......n”依次编号。然后从第1个人开始数,数到m把 踢出圈,其后的人再从1开始数,数到m,再把它踢出去...... 如此不停地进行下去直到最后只剩下一个人为止,那个人就是运气最佳。 具体需求如下所示。 编写函数模拟该游戏。 根据用户输入的m和n,指定人的总数n和踢出第m个人。 最后输出运气最佳的人的编号。
3条回答 默认 最新
- 冷寒越 2021-05-19 12:07关注
n = eval(input("请输入总人数:")) m = eval(input("请输踢出第几个人:")) list1 = [] for i in range(1, n+1): list1.append(i) while len(list1) != 1: if len(list1) >= m: list1 = list1[m:] + list1[0:m-1] print(list1) elif len(list1) < m: while len(list1) != 1: if m%len(list1) != 0: list1 = list1[m%len(list1):] + list1[0:m%len(list1)-1] else: list1 = list1[0:-2] print("最佳运气人编号为:%d号!"%list1[0])
这个可以吗?
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用