标题:n个人排队,围成圈,从第1个人开始报数到i ,每次报到i的人出列
取消只看楼主
zxq0103
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2023-3-10
结帖率:0
已结贴  问题点数:10 回复次数:1 
n个人排队,围成圈,从第1个人开始报数到i ,每次报到i的人出列
程序代码:
def bao_shu(n,i):
    """
        n个人排队,围成圈,从第1个人开始报数到i
        每次报到i的人出列,输出最后留下的人是几
        并输出每次出列的顺序
    """
    print('出列的顺序为:',end=' ')
    list01 = [x + 1 for x in range(n)]
    t = 0
    while n != 1:
        for p in range(i-1):
            t += 1
            if t == n:
                t = 0
        print(list01[t],end=' ')
        del list01[t]
        n -= 1
        if t == n:
            t = 0

    print()
    print('最后留下的人是:',list01[0])

bao_shu(34,3)

输出结果:
出列的顺序为: 3 6 9 12 15 18 21 24 27 30 33 2 7 11 16 20 25 29 34 5 13 19 26 32 8 17 28 4 22 1 23 14 31
最后留下的人是: 10


[此贴子已经被作者于2023-4-2 12:04编辑过]

搜索更多相关主题的帖子: 报数 顺序 输出 print 出列 
2023-04-02 11:44
zxq0103
Rank: 1
等 级:新手上路
帖 子:36
专家分:0
注 册:2023-3-10
得分:0 
回复 2楼 东海ECS
OK,懂你意思了
2023-04-02 12:24



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-511770-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.137772 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved