3.9美团笔试【java】第五题倒序并查集离散化


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

public class Main {
    public static class Pair{
        public int op;
        public int u;
        public int v;
        public Pair(int s,int l){
            u=s<l?s:l;
            v=u==s?l:s;
        }
        public Pair(int op, int s, int l) {
            this(s,l);
            this.op = op;
        }

        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;
            Pair pair = (Pair) o;
            return op == pair.op && u == pair.u && v == pair.v;
        }

        @Override
        public int hashCode() {
            return Objects.hash(op, u, v);
        }
    }
    static HashSet<Pair> fr=new HashSet<>();
    static ArrayList<Pair> qs=new ArrayList<>(1<<20);
    static ArrayList<String> ans=new ArrayList<>(1<<20);
    static HashMap<Integer,Integer> map_ren=new HashMap<>();
    static int[] f=new int[200010];
    static int[] size=new int[200010];
    static int[] help=new int[200010];
    public static  void init(){
        for (int i = 0; i < 200010; i++) {
            f[i]=i;
            size[i]=1;
        }
    }
    public static void main(String[] args) throws Exception {
        init();
        StreamTokenizer st = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        PrintWriter pw = new PrintWriter(new OutputStreamWriter(System.out));
        st.nextToken();
        int n = (int) st.nval;
        st.nextToken();
        int m = (int) st.nval;
        st.nextToken();
        int q = (int) st.nval;
        int id=1;
        while(m--!=0){
            st.nextToken();
            int u = (int) st.nval;
            if(map_ren.get(u)==null)map_ren.put(u,id++);
            st.nextToken();
            int v = (int) st.nval;
            if(map_ren.get(v)==null)map_ren.put(v,id++);
            Integer mu=map_ren.get(u);
            Integer mv=map_ren.get(v);
            fr.add(new Pair(mu,mv));
        }
        while(q--!=0){
            st.nextToken();
            int op = (int) st.nval;
            st.nextToken();
            int u = (int) st.nval;
            st.nextToken();
            int v = (int) st.nval;
            if(map_ren.get(u)==null)map_ren.put(u,id++);
            if(map_ren.get(v)==null)map_ren.put(v,id++);
            Integer mu=map_ren.get(u);
            Integer mv=map_ren.get(v);
            f[mu]=mu;
            f[mv]=mv;
            if(op==1){
                    if(fr.remove(new Pair(mu,mv)))
                        qs.add(new Pair(op,mu,mv));
            } else{
                qs.add(new Pair(op,mu,mv));
            }
        }
        for (Pair pair : fr) {
            union(pair);
        }
        for (int i = qs.size() - 1; i >= 0; i--) {
            Pair pair=qs.get(i);
            if(pair.op==2){
                if(find(pair.u)!=find(pair.v))
                    ans.add("No");
                else
                    ans.add("Yes");
            }else{
                union(pair);
            }
        }
        for (int i = ans.size() - 1; i >= 0; i--) {
            pw.println(ans.get(i));
        }
        pw.close();
    }

    private static void union(Pair pair) {
        int u= pair.u,v= pair.v;
        int fu=find(u),fv=find(v);
        if(fu!=fv){
            int sfu=size[fu];
            int sfv=size[fv];
            if(sfu<=sfv){
                f[fu]=fv;
                size[fv]=sfv+sfu;
            } else{
                f[fv]=fu;
                size[fu]=sfv+sfu;
            }
        }
    }

    private static int find(int u) {
        int top=0;
        while(f[u]!=u){
            help[top++]=u;
            u=f[u];
        }
        while(top!=0){
            f[help[--top]]=u;
        }
        return u;
    }
}

全部评论

相关推荐

面试官问:为什么不考研?该怎么回答啊😭我说现在的就业环境差到底了,还有就是我不想学数学,感觉面试官笑容都凝固了😢
DayDayNoBug的鲜芋球:我说的是“上学期其实尝试过去探索一些研究的方向,但感觉那些对我来说都没有很大的吸引力,相比起研究我可能更喜欢开发这种实践性的东西,它会让我觉得很有意思并且会为之深入进去”(虽然也不知这个回答怎么样哈哈哈哈哈哈)
点赞 评论 收藏
分享
大方的大熊猫准备进厂:1.教育背景:你希望从事什么专业的工作你的主修课就是什么;成绩优秀是你应该做的,没什么可描述的,成绩不优秀也许人家在大学忙着创业呢?(成绩优秀不一定是好事,只能说明多元化的大学你上成了高中,没有真正上明白大学,反而体现了你死板,不爱社交,没有别的突出能力) 2.实践经历:你想表达的意思没有说清楚。你是说你会个性化服务,还是你有实习经历。如果没有带来,经济收益,表彰,更好的发展前景,那你还不如说说提升了自己哪些技能。你说有人给你送锦旗我都能明白你优秀,但是你说你会xxxx,你说这话谁信,证据呢。 3.入伍经历:你描述的就是你的工作职责或者你应该做的,并没有体现出来你把这个事情做好了,而且入伍经历并不能证明你能干好你要应聘的工作,不如只写经历其余所有内容都不写。 4.荣誉技能:重点突出一下,但不要过多描述,这些荣誉的含金量懂得都懂。 重点:你要应聘什么工作(具体岗位,实习生不具体),你的期望薪资
点赞 评论 收藏
分享
学历算污点吗?
小何和:快毕业了,BOSS上的od闻着味就来了
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

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