洛谷P2661 信息传递 [NOIP2015] 并查集/乱搞 (待补充!
感觉我好水啊,,,做个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
洛谷P2661 信息传递 [NOIP2015] 并查集/乱搞 (待补充!的更多相关文章
- 洛谷 P2661 信息传递(并查集 & 最小环)
嗯... 题目链接:https://www.luogu.org/problemnew/show/P2661 这道题和一些比较水的并查集不太一样,这道题的思路就是用并查集来求最小环... 首先,如果我们 ...
- 洛谷 P2661 信息传递 Label:并查集||强联通分量
题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...
- 洛谷P2661 信息传递【并查集】
题目:https://www.luogu.org/problemnew/show/P2661 题意: 有一个有向图,问最小环的的大小. 思路: 明明是图的遍历,但是bfs会T.第二组下下来的数据n居然 ...
- 洛谷P2661 信息传递(最小环,并查集)
洛谷P2661 信息传递 最小环求解采用并查集求最小环. 只适用于本题的情况.对于新加可以使得两个子树合并的边,总有其中一点为其中一棵子树的根. 复杂度 \(O(n)\) . #include< ...
- 洛谷P2661 信息传递==coedevs4511 信息传递 NOIP2015 day1 T2
P2661 信息传递 题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知 ...
- 洛谷P2661 信息传递——并查集
给一手链接 https://www.luogu.com.cn/problem/P2661 这道题就是 并查集求最小环 TIPS:压缩路径的时候d[x]=d[fa[x]]+d[x],而不是d[x]=d[ ...
- 洛谷 P2661 信息传递 题解
P2661 信息传递 题目描述 有 \(n\) 个同学(编号为 \(1\) 到 \(n\) )正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为 \(i\) 的同学的信息传 ...
- [NOIP2015] 提高组 洛谷P2661 信息传递
题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...
- NOIP2015提高组T2 洛谷P2661 信息传递
题目描述 有n个同学(编号为1到n)正在玩一个信息传递的游戏.在游戏里每人都有一个固定的信息传递对象,其中,编号为i的同学的信息传递对象是编号为Ti同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...
随机推荐
- Nginx(五)-- 配置文件之Rewrite
Rewrite支持URL重写 1.常用指令以及语法 1) if指令 if语法: if 空格 (condition) {} 条件: 1. “=” 来判断相等,用于字符的比较 ...
- OSG添加回调更新
class CB : public osg::NodeCallback { virtual void operator()(osg::Node* node, osg::NodeVisitor* nv) ...
- 第二篇:Hadoop 在Ubuntu Kylin系统上的搭建[图解]
前言 本文介绍如何在Ubuntu Kylin操作系统上搭建Hadoop平台. 配置 1. 操作系统: Ubuntu Kylin 14.04 2. 编程语言: JDK 1.8 3. 通信协议: SSH ...
- React Native(四)——顶部以及底部导航栏实现方式
效果图: 一步一步慢慢来: 其实刚入手做app的时候,就应该做出简单的顶部以及底部导航栏.无奈又在忙其他事情,导致这些现在才整理出来. 1.顶部导航栏:react-native-scrollable- ...
- codeforces水题100道 第一题 Codeforces Beta Round #1 A. Theatre Square (math)
题目链接:http://www.codeforces.com/problemset/problem/1/A题意:至少用多少块边长为a的方块铺满NxM的矩形区域.C++代码: #include < ...
- struts.xml文件中配置tiles.xml
Apache Tiles是一个JavaEE应用的页面布局框架.Tiles框架提供了一种模板机制,可以为某一类页面定义一个通用的模板,该模板定义了页面的整体布局.布局由可以复用的多个块组成,每个页面可以 ...
- Eclipse安装php插件phpeclipse(转)
1.PHPEclipse是Eclipse的一个用于开发PHP的插件.官网下载地址:http://sourceforge.net/projects/phpeclipse/下载解压后,将features和 ...
- [原]rpm安装rpm-package报错:Header signature NOKEY 和 error: Failed dependencies:
以前经常遇到这个问题,一直未有记录,今天记录下来: 在安装rpm包的时候报错误如下: Question 1: warning: *.rpm: Header V3 DSA signature: NOKE ...
- mysql优化之伪哈希索引
想法非常简单,在标准的B-Tree索引上创建一个伪哈希索引.它和真正的哈希索引不是一回事,因为它还是使用B-Tree索引进行查找.然而,它将会使用键的哈希值进行查找,而不是键自身.你所要做的事情就是在 ...
- 【咸鱼教程】DragonBones帧动画、骨骼json、极速、二进制
公司的人想用龙骨,但是同事在官网找不着二进制的资料...于是写了个简单demo. demo中包含了帧动画.骨骼动画json.极速和二进制的资源和代码 测试环境:DragonBonesPro 5.5 ...