class Solution {
public:
int findTheWinner(int n, int k) {
}
};
1823. 找出游戏的获胜者
共有 n
名小伙伴一起做游戏。小伙伴们围成一圈,按 顺时针顺序 从 1
到 n
编号。确切地说,从第 i
名小伙伴顺时针移动一位会到达第 (i+1)
名小伙伴的位置,其中 1 <= i < n
,从第 n
名小伙伴顺时针移动一位会回到第 1
名小伙伴的位置。
游戏遵循如下规则:
1
名小伙伴所在位置 开始 。k
名小伙伴,计数时需要 包含 起始时的那位小伙伴。逐个绕圈进行计数,一些小伙伴可能会被数过不止一次。2
继续执行。给你参与游戏的小伙伴总数 n
,和一个整数 k
,返回游戏的获胜者。
示例 1:
输入:n = 5, k = 2 输出:3 解释:游戏运行步骤如下: 1) 从小伙伴 1 开始。 2) 顺时针数 2 名小伙伴,也就是小伙伴 1 和 2 。 3) 小伙伴 2 离开圈子。下一次从小伙伴 3 开始。 4) 顺时针数 2 名小伙伴,也就是小伙伴 3 和 4 。 5) 小伙伴 4 离开圈子。下一次从小伙伴 5 开始。 6) 顺时针数 2 名小伙伴,也就是小伙伴 5 和 1 。 7) 小伙伴 1 离开圈子。下一次从小伙伴 3 开始。 8) 顺时针数 2 名小伙伴,也就是小伙伴 3 和 5 。 9) 小伙伴 5 离开圈子。只剩下小伙伴 3 。所以小伙伴 3 是游戏的获胜者。
示例 2:
输入:n = 6, k = 5 输出:1 解释:小伙伴离开圈子的顺序:5、4、6、2、3 。小伙伴 1 是游戏的获胜者。
提示:
1 <= k <= n <= 500
进阶:你能否使用线性时间复杂度和常数空间复杂度解决此问题?
原站题解
python3 解法, 执行用时: 28 ms, 内存消耗: 14.8 MB, 提交时间: 2022-11-11 13:07:47
class Solution: def findTheWinner(self, n: int, k: int) -> int: winner = 1 for i in range(2, n + 1): winner = (k + winner - 1) % i + 1 return winner
python3 解法, 执行用时: 28 ms, 内存消耗: 15.3 MB, 提交时间: 2022-11-11 13:06:28
class Solution: def findTheWinner(self, n: int, k: int) -> int: return 1 if n == 1 else (k + self.findTheWinner(n - 1, k) - 1) % n + 1
python3 解法, 执行用时: 224 ms, 内存消耗: 15 MB, 提交时间: 2022-11-11 13:05:50
class Solution: def findTheWinner(self, n: int, k: int) -> int: q = deque(range(1, n + 1)) while len(q) > 1: for _ in range(k - 1): q.append(q.popleft()) q.popleft() return q[0]