趣题一则:寻找那扇门

简介:

现在出现在你面前的是一堵朝两个方向无限延伸的墙。墙上有一扇门,但你并不确定门离你有多远,也不知道门位于哪个方向(左边或是右边)。你只有在走到门面前才能看到它。假设从当前位置到门要走n步(n大小未知),那么怎样走O(n)步就能找到那扇门?

分析

这道题让人“左右为难”,因为不确定如何才能走到尽快确定方向和位置。首先想到在错误的方向上走得越远,就意味着离正确的位置越远,因此较为保险的方法是,第一步向右走,看看有没有门;第二步——为了防止在错误的方向上渐行渐远——向左走,走两步,这样就可以确定在最初位置的一步范围内有没有门了。

接下来,按照类似的方式左右徘徊,依次确定在最初位置的2,3,...,n有没有门了。不过,直觉上就会知道走了很多冤枉路,很可能不是O(n)了。下面来具体计算一下。

假设T(n)为按上述方法确定出左右各n步范围内是否有门所需要的步数,那么

T(1) = 2 + 1

T(2) = T(1) + 2*2 + 1

T(3) = T(2) + 2*3 + 1

...

T(n) = T(n-1) + 2*n + 1

两边相加,得T(n) = n^2 + 2*n,看来这个方法太慢了。

为了更好地分析慢的原因,我们从另一个角度来看上面的方法。将寻找门的过程看作一个个回合,初始位置标记为O,第一回合向右走一步,回到O,向左走一步,回到O;第二回合向右走二步,回到O,向左走二步,回到O;。。。;第n回合向右走n步,回到O,向左走n步,回到O。这样总的步数是4*(1+2+...+n)=2(n^2+n)。每个回合仅比上一回合多一步,造成的结果就是大量的重复。但如果考虑一种极端的情况,第一回合向右走n步,回到O,向左走n步,共n步,由于不知道n的大小,这算不上是一种有效的方法,但它说明,如果我们每个回合间的跨度够大,确实有可能达到O(n)。

在常见的渐进效率类型中,比多项式明显要大的是指数级,如2^n,这里先考察这种情况。即第i回合向右走2^i步,回到O,向左走2^i步,回到O,这里0<=i<=k且2^(k-1)<n<=2^k。这样经过k个回合就可以找到门的位置,总的步数是:

可以看到,这种新的回合制是符合要求的。接下来也许可以尝试更大的跨度,如3^n或n!甚至是n*n!,这里先不讨论了。

 

参考:

算法设计与分析基础


本文转自一个程序员的自省博客园博客,原文链接:http://www.cnblogs.com/anderslly/archive/2012/04/10/finding-the-door.html,如需转载请自行联系原作者

目录
相关文章
|
开发框架 .NET 芯片
电子技术实训——多功能数字钟的设计
电子技术实训——多功能数字钟的设计
电子技术实训——多功能数字钟的设计
|
11月前
|
机器学习/深度学习 人工智能 网络架构
深入理解深度学习中的卷积神经网络(CNN)
深入理解深度学习中的卷积神经网络(CNN)
215 1
|
算法
串ababaaababaa的next和串ababaabab的nextval
本文介绍了计算字符串的next数组和nextval数组的方法,通过分析两个具体的例子来展示如何计算这些数组,这些数组通常用于KMP算法中。
621 0
串ababaaababaa的next和串ababaabab的nextval
|
11月前
|
监控 API 数据安全/隐私保护
小红书详情API接口的获取与应用
在互联网信息爆炸的时代,小红书凭借丰富的用户生成内容(UGC)和精准的推荐系统迅速崛起,成为重要的社区电商平台。为了帮助开发者高效利用平台数据,小红书开放平台提供了多种API接口,涵盖商品详情和笔记详情等。本文详细介绍了如何注册、申请权限、构建请求、处理响应及应用这些API接口,旨在为开发者提供全面的指南,助力数据驱动的决策与创新。
4674 1
|
11月前
|
容器
wgcloud是什么软件
WGCLOUD是一款开源免费的主机/服务器管理软件,可以监测主机或者服务器的各种基础指标数据,比如内存、cpu、磁盘、网络、进程、端口、日志、容器等资源数据
|
机器学习/深度学习 数据采集 存储
使用机器学习算法进行文本分类的方法与实践
本文将介绍使用机器学习算法进行文本分类的方法与实践。通过分析文本特征、选择合适的机器学习算法和构建有效的训练模型,可以实现准确和高效的文本分类任务。我们还将探讨如何处理文本数据预处理、特征提取和模型评估等方面的关键问题,以帮助读者更好地应用机器学习技术解决文本分类挑战。
|
数据挖掘 OLAP OLTP
深入解析:OLTP与OLAP的区别与联系
【8月更文挑战第31天】
2827 0
|
存储 JSON 自然语言处理
数据标注工具 doccano | 命名实体识别(Named Entity Recognition,简称NER)
数据标注工具 doccano | 命名实体识别(Named Entity Recognition,简称NER)
239 1
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的员工工资管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的员工工资管理系统附带文章源码部署视频讲解等
203 1
|
存储 Android开发
方法:一键把一堆手机号码一次性快速导入手机通讯录
手机是人们日常沟通常用的工具,所以自然就要用到手机里面的通讯录联系。因此我们常要把别人的号码存入到手机通讯录里面,如果只是存五个十个那就动动手指就可以了。但是如果你想存把一个电脑excel表格里面的几百个、几千个、几万个等数量级别的联系人一键导入手机通讯录,显然手动一个个来存入是不现实的。我这里演示,通过借助网上常见的便捷工具软件,金芝号码提取导入助手,代替你手动工作来快速完成这个工作,如何一键把一堆手机号码一次性快速导入手机通讯录,省事省时省力。下面做个操作过程的图文讲解。
4702 0
方法:一键把一堆手机号码一次性快速导入手机通讯录