洛谷P2661 信息传递 [NOIP2015] 并查集/乱搞 (待补充!

时间:2022-04-06 12:49:08

感觉我好水啊,,,做个noip往年题目还天天只想做最简单的,,,实在太菜辽

然后最水的题目还不会正解整天想着乱搞,,,  虽然也搞出来辽233333

好滴不扯辽赶紧写完去做紫题QAQ

正解:并查集  /乱搞

解题报告:

ummm,,,因为我太弱辽还没有尝试并查集所以先写一发乱搞,,,

我发现我现在真滴好弱,,,我现在做题就是靠爆搜+数据结构再搞个优化骗分QAQ

umm乱搞就hin简单鸭,就顺着最傻逼的思路优化一下就over辽

首先是想到模拟嘛,一个个人地走,但这样肯定会超时noip应该不至于出这种,傻逼题?

然后你再看下题目,理解一下我们到底是要求什么?

最小环

那我们可以先把不是环的一部分的玩意儿给剔除

然后再进一步想

因为每个人只告诉一个人,那么每个环一定是相互独立的

然后你就可以,先筛选,然后bfs走一波看每个环多大就结束辽

然后优化就是,如果目前这个环还没扫完然而已经比我已知的答案要大了就直接退出,显然不是答案这不用思考嘛

然后就结束辽,,,

如果想再高大上一点可以先ran一个环?万一人品好还是可以节省点儿时间的

没了

哦忘记放代码辽QAQ

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define rp(i,x,y) for(register ll i=x;i<=y;++i)
ll n,fa[],ans=,rd[];
];
ll read()
{
    ;;
    '))ch=getchar();
    ;
    )+(x<<)+(ch^'),ch=getchar();
    return y?x:-x;
}
queue<ll>Q;
void cl(ll x)
{
    rd[fa[x]]--;
    if(!rd[fa[x]])cl(fa[x]);
    return;
}
void wk(ll x)
{
    ll cnt=;
    ll now=fa[x];
    ,now=fa[now],cnt++;>=ans)return;}
    ans=min(ans,cnt+);
    return;
}
int main()
{
    n=read();
    rp(i,,n)fa[i]=read(),rd[fa[i]]++;
    rp(i,,n)if(!rd[i])cl(i);
    rp(i,,n){if(rd[i] && !vis[i])wk(i);}
    printf("%lld",ans);
    ;
}

/*看到tag说是并茶几,,,开始也想到了,,,但是感觉无法实现所以本来准备放弃这个想法的
 然后认真地想了一下之后发现不会,我好像只能拿个暴力,,,不行真的心痛,,,太弱了!
所以还是认真想下这题并茶几的解趴quqqqqq*/

//,,,我有一个大胆的想法,,,是什么让我产生了暴力不行的想法啊,,,我觉得就开两个数组一步步跟着它爹走就出来了,,,我是不是想得太简单了QAQ

,,,我真蠢,真的QAQ

并查集解法还没做,周一之前会补上滴!

(哦其实我觉得也不是特别特别乱搞?有点图论的意思在里面趴?

然后开始我还想了下,我jio得可以用求强连通分量滴方法求?应该也是可以实现的趴?

over