博客
关于我
圆桌报数问题(剑指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/

你可能感兴趣的文章
Nginx 负载均衡与权重配置解析
查看>>
Nginx 负载均衡详解
查看>>
nginx 配置 单页面应用的解决方案
查看>>
nginx 配置https(一)—— 自签名证书
查看>>
nginx 配置~~~本身就是一个静态资源的服务器
查看>>
Nginx 配置解析:从基础到高级应用指南
查看>>
nginx+Tomcat性能监控
查看>>
Nginx下配置codeigniter框架方法
查看>>
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx.conf:128
查看>>
nginx添加模块与https支持
查看>>
Nginx用户认证
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>
Nginx的使用总结(二)
查看>>
Nginx的可视化神器nginx-gui的下载配置和使用
查看>>
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>