当前位置:网站首页>LeetCode. 剑指offer 62. 圆圈中最后剩下的数
LeetCode. 剑指offer 62. 圆圈中最后剩下的数
2022-07-06 17:52:00 【抠脚的大灰狼】
题目描述
0,1,···,n-1这n个数字排成一个圆圈,从数字0开始,每次从这个圆圈里删除第m个数字(删除后从下一个数字开始计数)。求出这个圆圈里剩下的最后一个数字。
例如,0、1、2、3、4这5个数字组成一个圆圈,从数字0开始每次删除第3个数字,则删除的前4个数字依次是2、0、4、1,因此最后剩下的数字是3。
思路
这是一个著名的数学问题 —— 约瑟夫环。
这里直接贴出解法(没有严格的数学证明,但比较容易理解和记忆)
用时光倒流法,从最后的情况开始,往回推。
借用一位大佬的图:

- 最后一轮(称之为第n轮),只剩一个数字(称之为
x)时,数组总大小为1,x的下标为0 - n-1轮中,
x是安全的,我们把整个环拉成一条无限长的直线,则容易知道,这一轮的起点,到x,有m个数,即x前面有m个数,且这一轮中移除的是x前面的那个数。那么该轮中x的下标为(m + 0) % 2(在x前面补上m个数),由于有环,我们取个模。这一轮保留了2个数。 - n-2轮中,上一轮的第一个数被保留了下来,说明n-1轮的第一个数前面有m个数,且该轮移除的是这个数前面的那个数。则在整个数组前面补上m个数,则n-1轮中所有数的下标都要往右移m,所以该轮中
x的下标为,(((m + 0) % 2) + m) % 3 - …
- 第1轮,还原到初始状态,就能求出
x在初始轮中的下标
class Solution {
public int lastRemaining(int n, int m) {
// 最后一轮的下标
int x = 0;
for (int i = 2; i <= n; i++) {
x = (x + m) % i;
}
return x;
}
}
公式为: f ( n , m ) = [ f ( n − 1 , m ) + m ] f(n,m) = [f(n-1,m) + m] % n f(n,m)=[f(n−1,m)+m],边界条件为 f ( 1 , m ) = 0 f(1,m)=0 f(1,m)=0
严谨的数学推导,参考:这或许是你能找到的最详细约瑟夫环数学推导! - 知乎
边栏推荐
- Yunna | work order management measures, how to carry out work order management
- 1123. The nearest common ancestor of the deepest leaf node
- Make Jar, Not War
- [100 cases of JVM tuning practice] 05 - Method area tuning practice (Part 2)
- 身体质量指数程序,入门写死的小程序项目
- NEON优化:log10函数的优化案例
- 移植DAC芯片MCP4725驱动到NUC980
- [case sharing] basic function configuration of network loop detection
- Share a general compilation method of so dynamic library
- 子网划分、构造超网 典型题
猜你喜欢

LLDP兼容CDP功能配置

AI 从代码中自动生成注释文档

MySQL script batch queries all tables containing specified field types in the database

域分析工具BloodHound的使用说明

今日问题-2022/7/4 lambda体中修改String引用类型变量

Yunna | work order management software, work order management software app

阿里云中mysql数据库被攻击了,最终数据找回来了

How to manage distributed teams?

第三方跳转网站 出现 405 Method Not Allowed

Yunna | work order management measures, how to carry out work order management
随机推荐
mysql: error while loading shared libraries: libtinfo. so. 5: cannot open shared object file: No such
Installation of gazebo & connection with ROS
Share a general compilation method of so dynamic library
7.6 simulation summary
2022 Google CTF SEGFAULT LABYRINTH wp
Segmenttree
交叉验证如何防止过拟合
taro3.*中使用 dva 入门级别的哦
自旋与sleep的区别
[Niuke] [noip2015] jumping stone
剑指 Offer II 035. 最小时间差-快速排序加数据转换
NEON优化:性能优化经验总结
负载均衡性能参数如何测评?
JS reverse -- ob confusion and accelerated music that poked the [hornet's nest]
第三方跳转网站 出现 405 Method Not Allowed
安利一波C2工具
[signal and system]
Realize incremental data synchronization between MySQL and ES
Byte P7 professional level explanation: common tools and test methods for interface testing, Freeman
Neon Optimization: performance optimization FAQ QA