题解 | 【模板】多重集合操作

【模板】多重集合操作

https://www.nowcoder.com/practice/aaf8b53f6ea74ad6beabed77bb275725

要注意,使用Map保存键值的时候,新增某个数,数量值记得加上原来的数值。删除某个数,是只删除一个,所以要先判断该数是否存在,然后更新数量。然后求集合的大小,这里应该是求的所有元素的值得数量总和,因此不能用size(),而是维护一个值的总数totalSize。

import java.util.*;

public class Main {
    // 静态变量
    static TreeMap<Integer, Integer> tm = new TreeMap<>();
    static int totalSize = 0;
    public static void insertValue(int x) {
        // TODO: 实现插入逻辑
        // 如果存在则是原来的数量+1
        // tm.putIfAbsent(x, 1); // 默认值为1
        tm.put(x, tm.getOrDefault(x, 0) + 1);
        totalSize++;
    }

    public static void eraseValue(int x) {
        // TODO: 实现删除逻辑
        // tm.remove(x); // 按照键删除
        // 删除只删除一个
        if (tm.containsKey(x)){
            int cnt = tm.get(x);
            if (cnt > 1) {
                tm.put(x, cnt - 1);
            }else {
                tm.remove(x);
            }
            totalSize--;
        }
    }

    public static int xCount(int x) {
        // TODO: 求x在集合中的个数
        return tm.getOrDefault(x, 0); // 默认不存在返回个数0
    }

    public static int sizeOfSet() {
        // TODO: 返回集合大小
        return totalSize;
    }

    public static int getPre(int x) {
        // TODO: 实现找前驱
        Integer pre = tm.lowerKey(x);
        return pre != null ? pre : -1;
    }

    public static int getBack(int x) {
        // TODO: 实现找后继
        // 使用导航方法即可,注意判断
        Integer back = tm.higherKey(x); 
        return back != null ? back : -1;
    }

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int q = scanner.nextInt();
        while (q-- > 0) {
            int op = scanner.nextInt();
            switch (op) {
                case 1:
                    insertValue(scanner.nextInt());
                    break;
                case 2:
                    eraseValue(scanner.nextInt());
                    break;
                case 3:
                    System.out.println(xCount(scanner.nextInt()));
                    break;
                case 4:
                    System.out.println(sizeOfSet());
                    break;
                case 5:
                    System.out.println(getPre(scanner.nextInt()));
                    break;
                case 6:
                    System.out.println(getBack(scanner.nextInt()));
                    break;
            }
        }
        scanner.close();
    }
}

#java#
全部评论

相关推荐

不愿透露姓名的神秘牛友
2025-12-17 16:48
今天九点半到公司,我跟往常一样先扫了眼电脑,屁活儿没有。寻思着没事干,就去蹲了个厕所,回来摸出手机刷了会儿。结果老板刚好路过,拍了我一下说上班别玩手机,我吓得赶紧揣兜里。也就过了四十分钟吧,我的直属领导把我叫到小隔间,上来就给我一句:“你玩手机这事儿把老板惹毛了,说白了,你可以重新找工作了,等下&nbsp;HR&nbsp;会来跟你谈。”&nbsp;我当时脑子直接宕机,一句话都没憋出来。后面&nbsp;HR&nbsp;找我谈话,直属领导也在旁边。HR&nbsp;说我这毛病不是一次两次了,属于屡教不改,不光上班玩手机,还用公司电脑看论文、弄学校的事儿。我当时人都傻了,上班摸鱼是不对,可我都是闲得发慌的时候才摸啊!而且玩手机这事儿,从来没人跟我说过后果这么严重,更没人告诉我在公司学个习也算犯错!连一次口头提醒都没有,哪儿来的屡教不改啊?更让我膈应的是,昨天部门刚开了会,说四个实习生里留一个转正,让大家好好表现。结果今天我就因为玩手机被开了。但搞笑的是,开会前直属领导就把我叫去小会议室,明明白白告诉我:“转正这事儿你就别想了,你的学历达不到我们部门要求,当初招你进来也没打算给你这个机会。”合着我没入贵厂的眼是吧?可我都已经被排除在转正名单外了,摸个鱼至于直接把我开了吗?真的太离谱了!
rush$0522:转正名单没进,大概率本来就没打算留你
摸鱼被leader发现了...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务