博客
关于我
圆桌报数问题(剑指offer-62)
阅读量:348 次
发布时间:2019-03-04

本文共 796 字,大约阅读时间需要 2 分钟。

题目描述:一圈共有N个人,开始报数,报到M的人自杀,然后重新开始报数,问最后自杀的人是谁?

解题思路一:使用一个大小为N的bool数组来保存每个人是否被杀,然后一直循环遍历这个数组,直到所有人都被杀死。在遍历过程中需要设置两个变量i和j,i变量表示报数的大小,j变量则是一个索引,当索引为j的人如果没有被杀死,则i加一,若i的报数刚好等于M,则把索引为j的人杀死。

解题思路二:使用一个队列来保存圆桌的每个人。接着,依次把从队头开始,把前M-1个人出队并给push到队列尾部,然后把队头的第一个元素pop,完成一个人的自杀。一直循环,直到队列只有一个人为止,则这个人为最后自杀的那个。

解题思路三:使用数学公式来计算最后自杀的人。通过对问题进行分析,可以发现最后自杀的人的位置与N和M的关系。假设每个人自杀的位置可以用一个公式来计算,最后自杀的人的位置可以通过(N*(M-1))%N来确定。

优化后的文章内容:

一圈共有N个人,开始报数,报到M的人自杀,然后重新开始报数,问最后自杀的人是谁?

解题思路一:使用一个大小为N的bool数组来保存每个人是否被杀,然后一直循环遍历这个数组,直到所有人都被杀死。在遍历过程中需要设置两个变量i和j,i变量表示报数的大小,j变量则是一个索引,当索引为j的人如果没有被杀死,则i加一,若i的报数刚好等于M,则把索引为j的人杀死。

解题思路二:使用一个队列来保存圆桌的每个人。接着,依次把从队头开始,把前M-1个人出队并给push到队列尾部,然后把队头的第一个元素pop,完成一个人的自杀。一直循环,直到队列只有一个人为止,则这个人为最后自杀的那个。

解题思路三:通过数学公式来计算最后自杀的人。通过对问题进行分析,可以发现最后自杀的人的位置与N和M的关系。假设每个人自杀的位置可以用一个公式来计算,最后自杀的人的位置可以通过(N*(M-1))%N来确定。

转载地址:http://ayqe.baihongyu.com/

你可能感兴趣的文章
nodejs配置express服务器,运行自动打开浏览器
查看>>
Nodemon 深入解析与使用
查看>>
node~ http缓存
查看>>
node不是内部命令时配置node环境变量
查看>>
node中fs模块之文件操作
查看>>
Node中同步与异步的方式读取文件
查看>>
Node中的Http模块和Url模块的使用
查看>>
Node中自启动工具supervisor的使用
查看>>
Node入门之创建第一个HelloNode
查看>>
node全局对象 文件系统
查看>>
Node出错导致运行崩溃的解决方案
查看>>
Node响应中文时解决乱码问题
查看>>
node基础(二)_模块以及处理乱码问题
查看>>
node安装及配置之windows版
查看>>
Node实现小爬虫
查看>>
Node提示:error code Z_BUF_ERROR,error error -5,error zlib:unexpected end of file
查看>>
Node提示:npm does not support Node.js v12.16.3
查看>>
Node搭建静态资源服务器时后缀名与响应头映射关系的Json文件
查看>>
Node服务在断开SSH后停止运行解决方案(创建守护进程)
查看>>
node模块化
查看>>