Java实现约瑟夫斯问题

约瑟夫斯问题源于一个历史故事,描述了人们如何按照特定规则淘汰,最终只剩一人。问题的本质是找到在n人围成一圈,按编号报数,报到k的人退出,直至只剩一人的过程中的幸存者。通过Java编程,可以实现这一问题的解决方案,得出最后的胜利者编号。
摘要由CSDN通过智能技术生成

1 问题描述
引用自《算法设计与分析基础》第三版:

约瑟夫斯问题,是以弗拉瓦斯。约瑟夫斯(Flavius Josephus)的名字命名的。约瑟夫斯是一个著名的犹太历史学家,参加并记录了公元66—70年犹太人反抗罗马的起义。约瑟夫斯作为一个将军,设法守住了裘达伯特的堡垒达47天之久,但在城市陷落了以后,他和40名顽强的将士在附近的一个洞穴中避难。在那里,这些反抗者表决说“要投降毋宁死”。于是,约瑟夫斯建议每个人应该轮流杀死他旁边的人,而这个顺序是由抽签决定的。约瑟夫斯有预谋地抓到了最后一签,并且,作为洞穴中的两个幸存者之一,他说服了他原先的牺牲品一起投降罗马。

上述是约瑟夫斯问题的起源,看完后个人感觉有点抽象,其实约瑟夫斯问题的本质为:n个人(编号由 1,2, …, n)围成一圈,由编号为1的人从1开始报数,报到k的退出自杀,剩下的人继续从1开始报数,直到圈内只剩余1人,求胜利者的编号。(n>0, k>0)

例如:

原n个人编号:

1 2 3 4 … … n-1 n

现在进行报数:

1 2 3 4… k(出列自杀) 1 2 …(循环报数,当到达编号为n的人时,下一个报数的从编号为1的人开始进行)

2 解决方案
约瑟夫斯问题的核心即找出给定n个人从前到后的自杀顺序,最后一个将要进行自杀的人即为幸存者。

具体编码如下:

package com.liuzhen.chapter4;

import java.util.Scanner;

pu
  • 19
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 14
    评论
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值