美团 小美的朋友关系 Java

import java.util.*;
import java.io.*;

public class Main {
    // 并查集:父节点映射 + 秩映射(按秩合并用)
    public static HashMap<Integer, Integer> parent = new HashMap<>();
  
    // 查找(路径压缩 + 自动初始化节点)
    public static int find(int x) {
        // 节点不存在则初始化:父节点是自己,秩为1
        parent.putIfAbsent(x, x);
        // 路径压缩(迭代版,避免递归栈溢出)
        while (!parent.get(x).equals(x)) {
            parent.put(x, parent.get(parent.get(x))); // 父节点指向祖父节点
            x = parent.get(x);
        }
        return x;
    }

    // 合并(按秩合并 + 路径压缩)
    public static void merge(int x, int y) {
        int rootX = find(x);
        int rootY = find(y);
        if (rootX == rootY) return;

        // 按秩合并:将秩小的树合并到秩大的树
        parent.put(rootY, rootX);
    }

    // 生成统一的边key(避免{a,b}和{b,a}重复)
    static String getRelationKey(int a, int b) {
        return a < b ? a + "," + b : b + "," + a;
    }

    public static void main(String[] args) throws IOException {
        // 替换Scanner为BufferedReader,提升输入效率
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] parts = br.readLine().split(" ");
        int n = Integer.parseInt(parts[0]);
        int m = Integer.parseInt(parts[1]);
        int q = Integer.parseInt(parts[2]);

        // 存储原始边
        Set<String> edges = new HashSet<>();
        for (int i = 0; i < m; ++i) {
            parts = br.readLine().split(" ");
            int a = Integer.parseInt(parts[0]);
            int b = Integer.parseInt(parts[1]);
            edges.add(getRelationKey(a, b));
        }

        // 存储有效操作(过滤无效删除)
        ArrayList<int[]> ops = new ArrayList<>();
        for (int i = 0; i < q; ++i) {
            parts = br.readLine().split(" ");
            int op = Integer.parseInt(parts[0]);
            int a = Integer.parseInt(parts[1]);
            int b = Integer.parseInt(parts[2]);

            if (op == 1) {
                String key = getRelationKey(a, b);
                if (edges.contains(key)) {
                    edges.remove(key);
                    ops.add(new int[]{op, a, b});
                }
            } else {
                ops.add(new int[]{op, a, b});
            }
        }

        // 初始化:合并所有未被删除的边(最终状态)
        for (String key : edges) {
            String[] nodes = key.split(",");
            int a = Integer.parseInt(nodes[0]);
            int b = Integer.parseInt(nodes[1]);
            merge(a, b);
        }

        // 倒序处理操作,记录答案
        List<Boolean> answers = new ArrayList<>();
        for (int i = ops.size() - 1; i >= 0; i--) {
            int[] op = ops.get(i);
            if (op[0] == 1) {
                // 原删除操作 → 逆操作:合并
                merge(op[1], op[2]);
            } else {
                // 原查询操作:判断是否连通
                boolean connected = find(op[1]) == find(op[2]);
                answers.add(connected);
            }
        }

        // 逆序输出答案
        for (int i = answers.size() - 1; i >= 0; --i) {
            System.out.println(answers.get(i) ? "Yes" : "No");
        }
    }
}
全部评论

相关推荐

1)歌尔精英计划&nbsp;alpha&nbsp;lab&nbsp;(上海)薪资:中base&nbsp;✖️14薪&nbsp;&nbsp;+&nbsp;留才奖工作内容:AR光学硬件方向,和博士研究方向十分对口;优点:工作强度较低,对AR显示行业有一些情结;缺点:从事的课题可能太偏预研了,个人目前最理想的工作内容是未来两到三年从事偏AI眼镜整体的产品开发性质工作。(2)禾赛科技&nbsp;光机部(上海)薪资:ssp(相比歌尔有不小优势)工作内容:激光雷达光学设计,未来拓展面可能拓展到激光雷达整体硬件;优点:理论上可以接触到不少产品化经验,可以学习的技术栈的范围会比较广;缺点:业务内容暂时熟悉度不高,技术栈和AR显示还是有一定差距,未来如果再想进入AI眼镜行业难度会比较大。个人情况:对于工作强度有一定的接受能力,具备一定的事业心,对AI/AR眼镜行业有一些情结,前两年还是希望比较扎根某项技术栈,未来向T字型人才发展,偏技术管理类的角色。希望大家可以从自己的视角给出自己的意见,如果大家了解以上offer中部门的相关信息,无论是私信还是评论,都十分感谢!如果大家有相关想要交流的,也欢迎私信,我能够解答的在看到之后也会尽量解答。处在职业生涯选择点,也非常理解其他面临选择的友友们的心情,希望大家可以互相帮助,互相支持!禾赛
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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