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;
}
相关推荐
Smark.3 小时前
(leetcode算法题)137. 只出现一次的数字 II
算法·leetcode
走在考研路上4 小时前
力扣896
python·算法·leetcode
Joyner20184 小时前
python-leetcode-整数转罗马数字
算法·leetcode·职场和发展
工一木子6 小时前
【Leecode】Leecode刷题之路第99天之恢复二叉搜索树
java·算法·leetcode·二叉树·中序遍历
Espresso Macchiato6 小时前
Leetcode 3407. Substring Matching Pattern
leetcode·字符串匹配·leetcode easy·leetcode 3407·leetcode双周赛147
Smark.6 小时前
(leetcode算法题)371. 两整数之和
算法·leetcode
KpLn_HJL6 小时前
leetcode - 1769. Minimum Number of Operations to Move All Balls to Each Box
算法·leetcode·职场和发展
清炒孔心菜9 小时前
每日一题 382. 链表随机节点
leetcode
圣保罗的大教堂9 小时前
leetcode 2274. 不含特殊楼层的最大连续楼层数 中等
leetcode
xiaoshiguang310 小时前
LeetCode:236. 二叉树的最近公共祖先
java·算法·leetcode