[算法][哈希表][排序] [leetcode]2225. 找出输掉零场或一场比赛的玩家

题目地址

https://leetcode.cn/problems/find-players-with-zero-or-one-losses/description/

题目描述

代码及思路

java 复制代码
class Solution {
    public List<List<Integer>> findWinners(int[][] matches) {
        //创建一个map记录比赛胜者组
        //创建一个map记录比赛败者组
        //全胜者不应该出现在败者组中
        //恰好只输了一场的在败者组中失败次数为1
        Map<Integer, Integer> winnerMap = new HashMap();
        Map<Integer, Integer> loserMap = new HashMap();
        for (int[] m : matches) {
            if (winnerMap.containsKey(m[0])) {
                winnerMap.put(m[0], winnerMap.get(m[0])+1);
            } else {
                winnerMap.put(m[0], 1);
            }

            if (loserMap.containsKey(m[1])) {
                loserMap.put(m[1], loserMap.get(m[1] )+1);
            } else {
                loserMap.put(m[1], 1);
            }
        }

        List<Integer> answers0List = winnerMap.keySet().stream().filter(e -> !loserMap.containsKey(e)).sorted().collect(Collectors.toList());
        List<Integer> answer1List = loserMap.entrySet().stream().filter(e->e.getValue()==1).map(e->e.getKey()).sorted().collect(Collectors.toList());

        List<List<Integer>> ans = new ArrayList<>();
        ans.add(answers0List);
        ans.add(answer1List);
        return ans;
    }
}
相关推荐
随意起个昵称7 小时前
区间dp-基础题目1(石子合并)
算法·动态规划
吞下星星的少年·-·7 小时前
线段树模板
算法
段一凡-华北理工大学7 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章11:演进路径与行业未来
大数据·网络·人工智能·算法·工业智能体·高炉炼铁智能化
叶小鸡8 小时前
小鸡玩算法-力扣HOT100-多维动态规划
算法·leetcode·动态规划
星马梦缘8 小时前
aaaaa
数据结构·c++·算法
菜菜的顾清寒9 小时前
力扣HOT100(42)链表-随机链表的复制
算法·leetcode·链表
lqqjuly9 小时前
模型剪枝与稀疏化:理论、算法与可运行实现
人工智能·算法·剪枝
逻辑君9 小时前
Foresight研究报告【20260011】
人工智能·线性代数·算法·矩阵
珊瑚里的鱼9 小时前
【动态规划】不同路径Ⅱ
算法·动态规划
适应规律10 小时前
【无标题】
人工智能·python·算法