【算法】约瑟夫环问题解析与实现

一、导言

约瑟夫环(Josephus Problem)是一个经典的数学问题,涉及一个编号为 1 到 n 的人围成一圈,从第一个人开始报数,报到某个数字 m 的人出列,然后再从下一个人开始报数,如此循环,直到所有人都出列。本篇博客将详细解析约瑟夫环问题,并使用 Python 实现算法。

二、问题分析

在约瑟夫环问题中,有两个变量需要确定:人数 n 和报数的数字 m。当给定 n 和 m 后,需要确定最后留下的人的编号。例如,当 n=7,m=3 时,约瑟夫环问题的过程如下:

  • 1 2 3 4 5 6 7 (初始状态)
  • 1 2 4 5 6 7(第3个人出列,报数到3)
  • 1 2 4 5 7(第6个人出列,报数到3)
  • 1 4 5 7(第2个人出列,报数到3)
  • 1 4 5(第7个人出列,报数到3)
  • 1 4(第5个人出列,报数到3)
  • 4(第1个人出列,报数到3)

因此,最后留下的人的编号为 4。

三、解决方案

解决约瑟夫环问题的一种常见思路是使用循环链表。首先,我们可以创建一个循环链表,并将人的编号作为节点的值。然后,从第一个节点开始,依次报数,当报数到达 m 时,移除当前节点,继续下一个节点,直到只剩下一个节点为止。

下面是使用 Python 实现约瑟夫环问题的代码:

"""
定义单向链表节点类
"""
class Node:def __init__(self, value):# 节点的值self.value = value# 指向下一个节点self.next = Noneclass CircularLinkedList:def __init__(self):self.head = Nonedef append(self, value):"""append: 在链表末尾添加一个新节点,如果链表为空,则将头节点指向新节点,新节点的 next 指针指向头节点,否则遍历链表找到尾节点并将其 next 指向新节点,同时新节点的 next 指针指向头节点,以形成循环:param value::return:"""new_node = Node(value)if not self.head:self.head = new_nodeself.head.next = self.headelse:current = self.head# 循环找到最后一个节点while current.next != self.head:current = current.nextcurrent.next = new_nodenew_node.next = self.headdef remove(self, value):"""从链表中移除一个值为 value 的节点遍历链表找到要移除的节点,并将其前一个节点的 next 指针跳过该节点,实现移除操作。:param value::return:"""if not self.head:# 头节点为空执行# 如果链表为空,则结束方法returncurrent = self.headprev = Nonewhile True:if current.value == value:if current == self.head:temp = self.headwhile temp.next != self.head:temp = temp.nexttemp.next = self.head.nextself.head = self.head.nextelse:prev.next = current.nextbreakprev = currentcurrent = current.nextif current == self.head:breakdef get_survivor(self, m):"""根据约瑟夫环问题,找到最后留下的人的编号,其中参数 m 表示每次移除第 m 个人。使用循环遍历链表,每次移除第 m 个节点,直到只剩下一个节点为止,返回该节点的值。:param m::return:"""current = self.headwhile current.next != current:count = 1while count != m:current = current.nextcount += 1self.remove(current.value)current = current.nextreturn current.valuedef josephus(n, m):linked_list = CircularLinkedList()for i in range(1, n+1):linked_list.append(i)return linked_list.get_survivor(m)if __name__ == '__main__':n = 5m = 2survivor = josephus(n, m)print(f"The survivor's number is: {survivor}")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/479682.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据分析案例-2023年TOP100国外电影数据可视化

🤵‍♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞&#x1f4…

SpringBoot+WebSocket实现即时通讯(四)

前言 紧接着上文《SpringBootWebSocket实现即时通讯(三)》 本博客姊妹篇 SpringBootWebSocket实现即时通讯(一)SpringBootWebSocket实现即时通讯(二)SpringBootWebSocket实现即时通讯(三&…

AI时代教师如何修炼内功

AI时代教师如何修炼内功 How Teachers Can Cultivate Their Inner Strength in the Age of AI 在AI时代,教师的角色和职责正在经历前所未有的变革。随着人工智能技术的不断进步,教育领域出现了许多新的工具和方法,这些新发展要求教师提升自身…

【C/C++】实现Reactor高并发服务器 完整版

代码结构 文件介绍 InetAddress.h InetAddress类 ip和端口设置 Socket.h Socket类 设置fd Epoll.h epollfd 管理类 Channel.h Channel类 管理epoll以及对应回调函数实现 EventLoop.h EventLoop事件循环类 TcpServer.h 服务器类 tcpepoll.cpp 主函数 InetAddress.h #if…

Linux用到的命令

1 压缩文件 tar -czf wonderful.tar.gz pm 这个命令的作用就是创建一个以.tar.gz结尾的包文件,然后调用gzip程序将当前目录下的pm文件夹压缩到这个以.tar.gz结尾的文件里面去

普中51单片机学习(二)

51单片机介绍 所需基础知识 基础数模电知识,简单的C语言。 PS:如果有不懂的直接通义千问。。。 什么是单片机 在一片集成电路芯片上集成微处理器、存储器、I/O接口电路,从而构成了单芯片微型计算机,即单片机。 学习方法 多实…

ActiveMQ高可用架构涉及常用功能整理

ActiveMQ高可用架构涉及常用功能整理 1. activemq的集群模式2. 镜像模式高可用系统架构和相关组件2.1 架构说明2.2 相关概念说明2.3 消息模型2.3.1 点对点2.3.2 发布订阅 3. activemq常用命令4. activemq配置集群5. 疑问和思考5.1 activemq的数据删除策略是怎样的?5…

医学生物化学与生物分子学试题及答案,分享几个实用搜题和学习工具 #经验分享#学习方法#其他

大学生的学习生活离不开一些实用的工具,它们能够帮助我们更高效地学习和管理时间。 1.大鱼搜题 这是一个公众号 包括教材课后习题,连冷门网课习题也能找到标准答案,日常练习和备考刷真题都离不开、 下方附上一些测试的试题及答案 1、仓储…

花费200元,我用全志H616和雪糕棒手搓了一台可UI交互的视觉循迹小车

常见的视觉循迹小车都具备有路径识别、轨迹跟踪、转向避障、自主决策等基本功能,如果不采用红外避障的方案,那么想要完全满足以上这些功能,摄像头、电机、传感器这类关键部件缺一不可,由此一来小车成本也就难以控制了。 但如果&a…

JavaWeb学习(1)数据库相关概念,mysql数据库管理系统,SQL语句

数据库相关概念 数据库: 存储数据的仓库,数据是有组织的进行存储 英文:DataBase 简称DB 数据库管理系统: 管理数据库的大型软件 英文:DataBase Management System,简称DBMS SQL 英文:Stry…

Java项目,营销抽奖系统设计实现

作者:小傅哥 博客:https://bugstack.cn 项目:https://gaga.plus 沉淀、分享、成长,让自己和他人都能有所收获!😄 大家好,我是技术UP主,小傅哥。 经过这个假期的嘎嘎卷🧨…

你真的了解—————NumPy吗

🌈个人主页:小田爱学编程 🔥 系列专栏:opencv 🏆🏆关注博主,随时获取更多关于IT的优质内容!🏆🏆 😀欢迎来到小田代码世界~ 😁 喜欢的…