约瑟夫环问题——学习笔记

本文介绍了约瑟夫环问题的背景故事及其本质,通过递推方式解析问题,并给出简洁的算法实现。文章提及的时间复杂度为O[n],并提到存在优化算法,链接指向更深入的讨论。
摘要由CSDN通过智能技术生成

约瑟夫环问题,经典的算法问题。

这个问题说的是一个小故事。在很久以前,有n个犹太人遭到敌人的追击,他们逃到了一个山洞中,大部分的人决定宁愿去死也不要让敌人抓住。他们围成一圈,一个个轮流报数,报到k的人就要当场自杀,然后下一个人从1开始重新数数。而约瑟夫不想自杀,于是他灵机一动,站到了圈的一个位置上,结果其他人一个个都自杀了,最后只剩下约瑟夫一个人还活着,最终他逃出了山洞。那么问题来了,约瑟夫站的是哪个位置呢?

这个问题的实质就是,n个人围成一个圈轮流数数,每次淘汰数到k的那个人,求最后剩下的人是谁。

这个问题有很多解法,但大多都是比较复杂的解决方法,在这里我先介绍一种巧妙的递推方式。先上递推关系式:

F[1]=0;
F[n]=(F[n-1]+k) mod n;

刚看这个公式估计会有点蒙,待我一步步说来。

首先为了编程方便,我们假定n个人的编号为0,1,...,n-1。

然后,F[n]是我们的目标函数,也就是最后剩下那个人的编号。

我们先假设已经知道F[n-1]的值,例如F[n-1]=P,也就是

0,1,...,P-1,P,P+1,...,N-2

那么我们怎么通过这个P来求的所需要的F[n]呢,实际上只需简单绕个弯。

由于n与n-1之间只相差1

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值