收藏文章 楼主
Python微课094 猴子选大王
版块:编程开发   类型:普通   作者:小羊羔links   查看:285   回复:0   获赞:0   时间:2022-01-24 00:10:01



看见更大的世界,遇见更好的自己。


See a better world to meet better for ourselves.



题目

猴子选大王

一群猴子要选新猴王。新猴王的选择方法是 让N只候选猴子围成一圈,从某位置起顺序编号为1 N号。

从第1号开始报数,每轮从1报到3,凡报到3的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数。

如此不断循环,最后剩下的一只猴子就选为猴王。请问是原来第几号猴子当选猴王?

这道题是典型的约瑟夫环问题。


参考答案
N = int(input("请输入猴子的数量 "))monkeys = []  # 列表中存储猴子在圈内(1表示 ,还是已经出圈(0表示 for i in range(1, N + 1):    monkeys.append(1)  # 开始,猴子都在圈内,全都赋值1print(monkeys)cnt = 0  # 报数n = N  # n存储了圈内猴子的数量,开始猴子都在圈内while n != 1:  # 重复执行直到剩下最后一只猴子    for i in range(0, N): # 遍历所有的猴子        if monkeys[i] == 1:  # 如果这只猴子还在圈内,才计数            cnt = cnt + 1  # 报数            if cnt == 3:  # 如果报到3                monkeys[i] = 0 # 猴子出局,将猴子标识为0                cnt = 0  # 从头开始报数                n = n 1  # 在圈的猴子数量减1print(monkeys.index(1) + 1) # 列表中为1的索引+1就是留下的猴子


小羊羔锚文本外链网站长https://seo-links.cn 
回复列表
默认   热门   正序   倒序

回复:Python微课094 猴子选大王

Powered by 免费发外链软文 7.12.4

©2015 - 2022 小羊羔外链网

免费发软文外链 鄂ICP备16014738号-6

您的IP:3.236.65.63,2022-11-29 19:25:39,Processed in 0.01704 second(s).

支持原创软件,抵制盗版,共创美好明天!
头像

用户名:

粉丝数:

签名:

资料 关注 好友 消息