Python猴子选大王

一群猴子要选新猴王。新猴王的选择方法是:让N只候选猴子围成一圈,从某位置起顺序编号为1~N号。从第1号开始报数,每轮从1报到3,凡报到3的猴子即退出圈子,接着又从紧邻的下一只猴子开始同样的报数。如此不断循环,最后剩下的一只猴子就选为猴王。请问是原来第几号猴子当选猴王?

输入格式:

输入在一行中给一个正整数N(≤1000)。

输出格式:

在一行中输出当选猴王的编号。

输入样例:

11

输出样例:

7
#循环队列筛选到最后一位
def f (n,total,counter_):
    #定义列表索引当前指针
    counter_list = -1
    while True:
        counter_ += 1
        counter_list += 1
        if n == 1:
            return total
        #若为当前最后一位则递归循环
        if counter_list == n:
            return f(n,total,counter_-1)
        if counter_ == 3:
            #更新报数器
            counter_ = 0
            #退出循环队列
            del total[counter_list]
            #回退指针
            counter_list -= 1
            #回退当前总个数
            n -= 1
#起始报数器
first_counter = 0
n = int(input())
#迭代号数
total = [int(x) for x in range(1,n+1)]
print(str(f(n,total,first_counter)).replace('[','').replace(']',''))

 以上代码全为本人亲自手敲,可能有一些错误和不足之处,如有更好的方法和建议,欢迎您在评论区友善讨论。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

付之一笑」༻

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值