热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

【阅读具体数学笔记】递归分类下的约瑟夫问题将递归式转化为封闭式

本书中的约瑟夫问题定义如下:从围成标有记号1到n的圆圈的n个人开始,每隔一个删去一个人,知道只有一个人幸存下来。下图是n10的起始图形:削去的顺序为2,4,6,8,10,
本书中的约瑟夫问题定义如下:从围成标有记号1到n的圆圈的n个人开始,每隔一个删去一个人,知道只有一个人幸存下来。

下图是n=10的起始图形:
这里写图片描述
削去的顺序为2,4,6,8,10,3,7,1,9,于是最后有5幸存下来。问题是对总人数为n时,幸存者的号码J(n)是多少?
首先面对这个问题的时候,由于题目数据比较少,我们会来时一步一步的推导,第一次循环的时候,从2开始削去了环中的所有偶数,所以我们知道了最后题目的结果肯定是一个奇数。随着一轮一轮的循环删除在环中的数据规模不断缩小,所以我们把它抽象成如下形式:
我们假设一开始有2n个人,经过第一轮消除所有偶数之后编程如下形式:
这里写图片描述
下一个离开的就是3号(因为上一个删除了2n),对比开始没有进行删除的情况我们可以知道,按顺序删除的每个数据变成了之前的数据加倍再减去一,就是说

J(2n)=2J(n)-1,n>=1.

下面再来考虑对于奇数的情形,对于2n+1个人,标号为1的人恰好在标号为2n的人之后被删除,我们类比2n的情形可以得到
这里写图片描述
J(2n+1)=2J(n)+1,n>=1.

将以上的方程和J(1)=1组合起来就可以得到在所有情形下定义J的递归式:
J(1)=1.
J(2n)=2J(n)-1,n>=1.
J(2n+1)=2J(n)+1,n>=1.

为了能够在有限次运算内求得指定的J(n),我们来将递归式求得封闭形式:
对一个递归式,发现规律的最好方法就是将数据打表
这里写图片描述
我们发现表中的数据以2的幂将表分组(1,2,4,8…),并且每一组中的数据都是在递增2。所以我们可以讲n表示成n=2^m+l,m是使2^m不超过n的最大幂次,l表示在每一个分组中所占的位置,此时的递归式的解可以表示为

J(2^m +l)=2*l+1,m>=0,0<=l<2^m.

下面给出上式的证明,我们对m使用归纳法:当m=0时必定有l=0,所以上式的基础就是J(1)=1,此结论为真。归纳证明分为l是偶数还是奇数,如果m>0并且2^m+l=2n,那么l是偶数,那么根据归纳假设有:

J(2^m+l)=2J(2^(m-1)+l/2)-1=2l+1.

这就是我们想要的结果。当2^m=2n+1为奇数,我们同样有类似的证明成立。
我将在下一篇文章中给出文中递推式的推广,这些探讨将会解释所有这类问题背后的隐藏结构。


推荐阅读
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 本文详细介绍 Go+ 编程语言中的上下文处理机制,涵盖其基本概念、关键方法及应用场景。Go+ 是一门结合了 Go 的高效工程开发特性和 Python 数据科学功能的编程语言。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • python的交互模式怎么输出名文汉字[python常见问题]
    在命令行模式下敲命令python,就看到类似如下的一堆文本输出,然后就进入到Python交互模式,它的提示符是>>>,此时我们可以使用print() ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 本文详细探讨了Java中的24种设计模式及其应用,并介绍了七大面向对象设计原则。通过创建型、结构型和行为型模式的分类,帮助开发者更好地理解和应用这些模式,提升代码质量和可维护性。 ... [详细]
  • 如何查找和管理计算机中的C盘临时文件
    本文详细介绍了如何在计算机中找到和管理C盘的临时文件,包括其具体路径、环境变量设置方法以及清理这些文件对系统性能的影响。对于希望优化系统性能和释放磁盘空间的用户来说,这是一篇非常有价值的参考。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • c# – UWP:BrightnessOverride StartOverride逻辑 ... [详细]
  • 解决Linux系统中pygraphviz安装问题
    本文探讨了在Linux环境下安装pygraphviz时遇到的常见问题,并提供了详细的解决方案和最佳实践。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
author-avatar
手机用户2602914627
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有