leetcode 3238. 求出胜利玩家的数目 简单

给你一个整数 n ,表示在一个游戏中的玩家数目。同时给你一个二维整数数组 pick ,其中 pick[i] = [xi, yi] 表示玩家 xi 获得了一个颜色为 yi 的球。

如果玩家 i 获得的球中任何一种颜色球的数目 严格大于 i 个,那么我们说玩家 i 是胜利玩家。换句话说:

  • 如果玩家 0 获得了任何的球,那么玩家 0 是胜利玩家。
  • 如果玩家 1 获得了至少 2 个相同颜色的球,那么玩家 1 是胜利玩家。
  • ...
  • 如果玩家 i 获得了至少 i + 1 个相同颜色的球,那么玩家 i 是胜利玩家。

请你返回游戏中 胜利玩家 的数目。

注意,可能有多个玩家是胜利玩家。

示例 1:

**输入:**n = 4, pick = [[0,0],[1,0],[1,0],[2,1],[2,1],[2,0]]

**输出:**2

解释:

玩家 0 和玩家 1 是胜利玩家,玩家 2 和玩家 3 不是胜利玩家。

示例 2:

**输入:**n = 5, pick = [[1,1],[1,2],[1,3],[1,4]]

**输出:**0

解释:

没有胜利玩家。

示例 3:

**输入:**n = 5, pick = [[1,1],[2,4],[2,4],[2,4]]

**输出:**1

解释:

玩家 2 是胜利玩家,因为玩家 2 获得了 3 个颜色为 4 的球。

提示:

  • 2 <= n <= 10
  • 1 <= pick.length <= 100
  • pick[i].length == 2
  • 0 <= xi <= n - 1
  • 0 <= yi <= 10

分析:由于玩家数量最大为10,所有球的种类最大为10,可以建立一个玩家数组,标记每个玩家的每种球的个数。遍历pick数组,当当前玩家的当前颜色的球超过玩家编号时,记录该玩家为胜利玩家。

cpp 复制代码
int winningPlayerCount(int n, int** pick, int pickSize, int* pickColSize) {
    int player[n+5][11],ans[n+5];
    for(int i=0;i<n;++i)
    {
        ans[i]=0;
        for(int j=0;j<11;++j)
            player[i][j]=0;
    }

    for(int i=0;i<pickSize;++i)
    {
        int l=pick[i][0],r=pick[i][1];
        player[l][r]++;
        if(player[l][r]>l)ans[l]=1;
    }
    int cnt=0;
    for(int i=0;i<n;++i)
        if(ans[i])cnt++;
    return cnt;
}
相关推荐
6Hzlia9 小时前
【Hot 100 刷题计划】 LeetCode 199. 二叉树的右视图 | C++ DFS 逆序遍历
c++·leetcode·深度优先
踩坑记录11 小时前
leetcode hot100 118. 杨辉三角 easy 动态规划
leetcode·动态规划
木井巳12 小时前
【递归算法】解数独
java·算法·leetcode·决策树·深度优先·剪枝
上弦月-编程12 小时前
企业级RAG系统构建指南
leetcode
阿Y加油吧12 小时前
算法实战笔记:LeetCode 31 下一个排列 & 287 寻找重复数
笔记·算法·leetcode
穿条秋裤到处跑12 小时前
每日一道leetcode(2026.04.24):距离原点最远的点
算法·leetcode·职场和发展
踩坑记录12 小时前
121. 买卖股票的最佳时机 easy 贪心算法
leetcode
叶小鸡13 小时前
小鸡玩算法-力扣HOT100-贪心算法
算法·leetcode·贪心算法
superior tigre14 小时前
45 跳跃游戏2
算法·leetcode·游戏
田梓燊15 小时前
力扣:138.随机链表的复制
算法·leetcode·链表