洛谷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同学. 游戏开始时,每人都只知道自己的生日.之后每一 ...
随机推荐
- iOS开发-- 设置UIButton的文字显示位置、字体的大小、字体的颜色
btn.frame = CGRectMake(x, y, width, height); [btn setTitle: @"search" forState: UIControlS ...
- spring boot配置文件application.propertis
转自http://www.qiyadeng.com/post/spring-boot-application-properties 本文记录Spring Boot application.proper ...
- java 读写文件例子
在linux下可以读写中文 import java.io.*; import java.text.SimpleDateFormat; import java.util.*; public class ...
- Mac下Intellij IDea发布JavaWeb项目 详解二 (新建Module)
Step3 添加两个module 3.1 右键[WebWorkSpace]-[New]-[Module] 3.2 重复 准备工作1:新建第一个JavaWeb项目[1.6-1.11]的操作,建好一个名为 ...
- SQL - ROW_NUMBER,Rank 添加序号列
百度的时候查到的博客: http://blog.csdn.net/xsfqh/article/details/6663895-------------------------------------- ...
- 原生js--insertAdjacentHTML
insertAdjacentHTML是IE浏览器提供向DOM中插入html字符串的方法,字符串会自动生成在DOM树中. 其调用方式为elem.insertAdjacentHTML( position, ...
- LinQ实战学习笔记(一) LINQ to (Objects, XML, SQL) 入门初步
LINQ对于笔者来说, 优美而浓缩的代码让人震惊. 研究LINQ就是在艺术化自己的代码. 之前只是走马观花学会了基本的语法, 但是经常在CSDN看到令人惊讶自叹不如的LINQ代码, 还是让人羡慕嫉妒恨 ...
- MyBatis学习之输入输出类型
1. 传递pojo对象 Mybatis使用ognl表达式解析对象字段的值,#{}或者${}括号中的值为pojo属性名称,其中,#{}:占位符号,好处防止sql注入,${}:sql拼接符号, 简要说明 ...
- LeetCode 35 Search Insert Position(查找插入位置)
题目链接: https://leetcode.com/problems/search-insert-position/?tab=Description 在给定的有序数组中插入一个目标数字,求出插入 ...
- 提高VS2010运行速度的技巧
任务管理器,CPU和内存都不高,为何?原因就是VS2010不停地读硬盘导致的; 写代码2/3的时间都耗在卡上了,太难受了; 研究发现,VS2010如果你装了VC等语言,那么它就会自动装SQL Serv ...