须知
题目描述
100个人围成一圈,每个人有一个编码,编号从1开始到100。
他们从1开始依次报数,报到为M的人自动退出圈圈,然后下一个人接着从1开始报数,直到剩余的人数小于M。
请问最后剩余的人在原先的编号为多少?
输入描述
输入一个整数参数 M
输出描述
如果输入参数M小于等于1或者大于等于100,输出“ERROR!”;
否则按照原先的编号从小到大的顺序,以英文逗号分割输出编号字符串
用例
输入 3
输出 58,91
说明 输入M为3,最后剩下两个人。
输入 4
输出 34,45,97
说明 输入M为4,最后剩下三个人。
解题思路:
- 首先判断输入的M是否在合理范围内,即大于1且小于100。
- 创建一个列表,用于存储每个人的编号。
- 使用循环遍历列表,每次报数加1。
- 如果报数为M,则将该人从列表中移除,并将报数重置为1。
- 当列表中剩余人数小于M时,结束循环。
- 输出剩余人的编号。
Python代码如下:
def
华为OD机试C卷:报数游戏Python解法

100人围圈报数,报到M的人退出,直至剩余人数少于M。输入M判断范围,输出剩余人在原始编号。用例:输入3,输出58,91;输入4,输出34,45,97。Python解题思路:判断M范围,创建编号列表,循环报数,报到M则移除,输出剩余编号。"
104932950,9385783,计算二叉树直径的C++解决方案,"['二叉树', '数据结构', '算法']
订阅专栏 解锁全文
514





