python约瑟夫环「建议收藏」

python约瑟夫环「建议收藏」第一次出队的那个人的编号是(m-1)%n,第二次重新开始的编号是m%n约瑟夫环是一个经典的数学问题,我们不难发现这样的依次报数,似乎有规律可循。为了方便导出递推式,我们重新定义一下题目。 问题: N个人编号为1,2,……,N,依次报数,每报到M时,杀掉那个人,求最后胜利者的编号。这边我们先把结论抛出了。之后带领大家一步一步的理解这个公式是什么来的。 一般解法找到出列的人,把它删…

大家好,又见面了,我是你们的朋友全栈君。

第一次出队的那个人的编号是( m-1)%n ,第二次重新开始的编号是m%n

约瑟夫环是一个经典的数学问题,我们不难发现这样的依次报数,似乎有规律可循。为了方便导出递推式,我们重新定义一下题目。 
问题: N个人编号为1,2,……,N,依次报数,每报到M时,杀掉那个人,求最后胜利者的编号。

这边我们先把结论抛出了。之后带领大家一步一步的理解这个公式是什么来的。 

一般解法

找到出列的人,把它删掉。这个人的编号是(m-1)%n,m是报数,n是总的人数

时间复杂度是O(nm)
递推公式: 

f(N,M)=(f(N−1,M)+M)%N

  • f(N,M)表示,N个人报数,每报到M时杀掉那个人,最终胜利者的编号
  • f(N−1,M)表示,N-1个人报数,每报到M时杀掉那个人,最终胜利者的编号

公式理解:

python约瑟夫环「建议收藏」

python 代码:

# -*- coding:utf-8 -*-
class Solution:
    def LastRemaining_Solution(self, n, m):
        # write code here
        # 用列表来模拟环,新建列表range(n),是n个小朋友的编号
        if not n or not m:
            return -1
        lis = range(n)
        i = 0
        while len(lis)>1:
            i = (m-1 + i)%len(lis) # 递推公式
            lis.pop(i)
        return lis[0]

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136192.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月3日 下午11:36
下一篇 2022年6月3日 下午11:46


相关推荐

  • Pycharm远程开发

    Pycharm远程开发可以在 Windows 中使用 Pycharm 编写代码 而代码的调试运行可以使用远程服务器中的 python 解释器 在本地创建好工程项目 或从 git 上 clone 下代码 后 用 Pycharm 打开 打开 Tools 设置 Deployment 2 选择 SFTP3 设置服务器名字 4 设置服务器信息 4 images pycharm 远程配置 4 png 5 测试服务器连接是否可用

    2026年3月27日
    2
  • java jersey,java Jersey

    java jersey,java Jersey场景:用Jersey构建RESTful服务3-JAVA对象转成JSON输出用Jersey构建RESTful服务3–JAVA对象转成JSON输出一、总体说明XML和JSON是最为常用的数据交换格式。本例子演示如何将java对象,转成JSON输出。二、流程1.在上文项目中,在“com.waylau.rest.resources.UserResource“中增加代码,代码如下:@GET@Path(…

    2022年7月27日
    8
  • shell if条件判断_shell if 判断

    shell if条件判断_shell if 判断,

    2022年8月18日
    9
  • 概率论机器学习的先验知识(上)

    概率论机器学习的先验知识(上)

    2022年1月2日
    57
  • document.getElementById 用法

    document.getElementById 用法 document.getElementById使用   注意:document.getElementById(“”)得到的是一个对象,用alert显示得到的是“object”,而不是具体的值,它有value和length等属性,加上.value得到的才是具体的值! 参考资料:1.docum

    2022年7月15日
    20
  • mysql中explain的用法_mysql substr用法

    mysql中explain的用法_mysql substr用法基于Mysql5.7版本的explain参数详解…Mysql官网相关参数解读一:idSELECT标识符1.id越大越先执行2.相同id,从从往下执行二:select_type1.SIMPLE:最简单的查询(没有关联查询没有子查询没有union的查询语句)2:PRIMARY:子查询最外层的查询语句3.SUBQUERY:子查询内层查询语句4.DERIVED:派生表查询,FROM后的不是表而是查询后的结果集5.UNION:union或unionall中的第二个以后的查询表6.U

    2022年8月31日
    11

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号