public class Solution {
// 左神解法,本题本质还是报数为m-1的倍数的人死。求最后一个活着的人是初始时候的哪个人
/* 报数(A) 实际人员编号(B)
0 0
. .
. .
n-1 n-1
n 0
则可知B = A % n
同时,当杀了一个人之后,杀人前记为before,杀人后记为after.
before after
k (k < n) (没有了,因为被杀后变为n-1个人了)
k+1 0
. .
. .
n-2 n-k-3
0 n-k-2
. .
. .
k-1 n-2
符合公式before = (after + k + 1) % n
可知,最后一个活着的人为0号,因此可以利用逆推的方法求得活着的那个人。*/
public int LastRemaining_Solution(int n, int m) {
if (n < 1 || m < 1) {
return -1;
}
int live = getLive(n, m);
return live;
}
public int getLive(int n, int m) {
if (n == 0) {
return 0;
}
return (getLive(n - 1, m) + m) % n;
}