2023-08-16 LeetCode每日一题(找出转圈游戏输家)

2023-08-16每日一题

一、题目编号

2682. 找出转圈游戏输家

二、题目链接

点击跳转到题目位置

三、题目描述

n 个朋友在玩游戏。这些朋友坐成一个圈,按 顺时针方向 从 1 到 n 编号。从第 i 个朋友的位置开始顺时针移动 1 步会到达第 (i + 1) 个朋友的位置(1 <= i < n),而从第 n 个朋友的位置开始顺时针移动 1 步会回到第 1 个朋友的位置。

游戏规则如下:

第 1 个朋友接球。

  • 接着,第 1 个朋友将球传给距离他顺时针方向 k 步的朋友。
  • 然后,接球的朋友应该把球传给距离他顺时针方向 2 * k 步的朋友。
  • 接着,接球的朋友应该把球传给距离他顺时针方向 3 * k 步的朋友,以此类推。
  • 换句话说,在第 i 轮中持有球的那位朋友需要将球传递给距离他顺时针方向 i * k 步的朋友。

当某个朋友第 2 次接到球时,游戏结束。

在整场游戏中没有接到过球的朋友是 输家

给你参与游戏的朋友数量 n 和一个整数 k ,请按升序排列返回包含所有输家编号的数组 answer 作为答案。

四、解题代码

class Solution {
    unordered_map<int, int> hash;    
public:
    vector<int> circularGameLosers(int n, int k) {
        int i = 0;
        int m = 1;
        while(hash[i] == 0){
            hash[i] = 1;
            i = (i + m * k) % n;      
            ++m;
        }
        vector<int> res;
        for(int i = 0; i < n; ++i){
            if(hash[i] == 0){
                res.push_back(i+1);
            }
        }
    return res;
    }
};

五、解题思路

你可能感兴趣的:(LeetCode每日一题,leetcode,数据结构,算法)