约瑟夫环

发布时间:2020-05-01 04:39:37 作者:Jayce_SYSU
来源:网络 阅读:406
# -*- coding: utf-8 -*-
# @Time         : 2019-09-18 21:57
# @Author       : Jayce Wong
# @ProjectName  : job
# @FileName     : josephus.py
# @Blog         : https://blog.51cto.com/jayce1111
# @Github       : https://github.com/SysuJayce

"""
约瑟夫斯(Josephus)问题是一个出现在计算机科学和数学中的问题。
在计算机编程的算法中,类似问题又称为约瑟夫环。
约瑟夫斯问题:有n个囚犯站成一个圆圈,准备处决。
首先从一个人开始,越过k-2个人(因为第一个人已经被越过),并杀掉第k个人。
接着,再越过k-1个人,并杀掉第k个人。
这个过程沿着圆圈一直进行,直到最终只剩下一个人留下,这个人就可以继续活着。

给定了n和k,一开始要站在什么地方才能避免被处决?

递推公式:
当n = 1时,f(1, k) = 1
当n > 1时,f(n, k) = (f(n - 1, k) + k) mod n
**注意**当编号从1开始的时候,如果计算得到f(n, k) = 0,那么需要将其还原为n然后继续递推
"""

def josephus(n, k):
    if n <= 1:
        return 1
    res = 1
    # 注意这里我们使用递推公式的时候,计算的是f(i, k),因此需要对i取模
    for i in range(2, n + 1):
        res = (res + k) % i if (res + k) % i != 0 else i
    return res

print(josephus(5, 2))
推荐阅读:
  1. 如何用golang实现约瑟夫环
  2. 单向循环链表(约瑟夫环)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

递推

上一篇:servlet3.0文件上传

下一篇:HTML 转义字符

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》