4.1 食物链(带权并查集)

题目链接

食物链

题目思路:带权并查集

设0为a,b同级 a1b为a吃b a2b为b吃a
第一次写带权并查集,希望在最近的刷题中能有所提高

代码实现

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const int Max=1e6;
int n,k;
int ft[Max],d[Max];
void init()
{
    for(int i=1;i<=n;i++)
        ft[i]=i;
}
int find(int x)
{
    if(ft[x]==x) return x;
    else
    {
        int t=find(ft[x]);
        d[x]+=d[ft[x]];
        ft[x]=t;
    }
    return ft[x];
}
int main()
{
    cin>>n>>k;
    init();
    int sum=0;
    while(k--)
    {
        int c,a,b;
        cin>>c>>a>>b;
        if(a>n||b>n)
        {
            sum++;
            continue;
        }
        else
        {
            int fa=find(a),fb=find(b);
            if(c==1)
            {
                if(fa==fb&&(d[b]-d[a])%3!=0)
                    sum++;
                else if(fa!=fb)
                {
                    ft[fa]=fb;
                    d[fa]=d[b]-d[a];
                }
            }
            else if(c==2)
            {
                if(fa==fb&&(d[a]-d[b]+1)%3!=0)
                    sum++;
                else if(fa!=fb)
                {
                    ft[fa]=fb;
                    d[fa]=d[b]-d[a]+2;
                }
            }
        }
    }
    cout<<sum<<endl;
    return 0;
}
全部评论

相关推荐

屌丝逆袭咸鱼计划:心态摆好,man,晚点找早点找到最后都是为了提升自己好进正职,努力提升自己才是最关键的😤难道说现在找不到找的太晚了就炸了可以鸡鸡了吗😤早实习晚实习不都是为了以后多积累,大四学长有的秋招进的也不妨碍有的春招进,人生就这样
点赞 评论 收藏
分享
05-14 20:34
门头沟学院 Java
窝补药贝八股:管他们,乱说,反正又不去,直接说680
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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