小学生蓝桥杯Python闯关 | 约瑟夫环

Posted COCOgsta

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小学生蓝桥杯Python闯关 | 约瑟夫环相关的知识,希望对你有一定的参考价值。

学习Python从娃娃抓起!记录下蓝桥杯Python学习和备考过程中的题目,记录每一个瞬间。

附上汇总贴:小学生蓝桥杯Python闯关 | 汇总_COCOgsta的博客-CSDN博客


【题目描述】

有n个人围城一个圈,按顺序排号号。然后从第一个人开始报数(从1到3报数),报到3的人退出圈子,然后继续从1到3报数,直到最后留下一个人游戏结束,问最后留下的是原来第几号。

【输入描述】

输入一个正整数

【输出描述】

输出最后留下的是原来的第几号

【样例输入】

5

【样例输出】

4

【代码详解】

n = int(input())
ls = [1 for i in range(n)]
p = 0
while ls.count(1) > 1:
    cnt = 0
    while cnt < 3:
        if ls[p%n] == 1:
            cnt += 1
        p += 1
    ls [p%n -1] = 0
print(ls.index(1) + 1)
复制代码

【运行结果】

5
4

以上是关于小学生蓝桥杯Python闯关 | 约瑟夫环的主要内容,如果未能解决你的问题,请参考以下文章

小学生蓝桥杯Python闯关 | 密码创建

小学生蓝桥杯Python闯关 | 回文日期

小学生蓝桥杯Python闯关 | 纯质数

小学生蓝桥杯Python闯关 | 移动方格

小学生蓝桥杯Python闯关 | 健康判断

小学生蓝桥杯Python闯关 | 数的性质