[agc006F]Blackout
Description
Solution
这道题的操作是真的得服气。。感谢各位大佬的指导。
首先我们看看答案的最大值:1010。哦不,这不可能存在,我们肯定不可能一轮轮枚举点进行扩展的。
所以,接下来我们进入正题:
由于我们不可能计算出所有具体的点,我们肯定得依靠某种玄学秘法来表示原本的点(不然你没法往下推啊qaq),然后通过神秘手段来搞事情。
em我们把一个点(x,y)看做是一条x->y的有向边。如果有x->y,y->z,则我们可以加上边z->x。
这些点将构成若干联通块,我们对其进行染色。
我们一共染3种色0,1,2。如果有x->y,则y的颜色为(x的颜色+1)%3。
对于某个联通块,有3种情况。
1,一共只用了两种颜色并且没有一个点被染了两种色,我们可以形象地理解为该图只有两层,但是我们需要3层才可以额外加边,答案不变。
2,一共刚好用了3色并且没有一个点被染了两种色,则2色的可以连向0色,0色的可以连向1色,1色的可以连向2色,统计加了多少边就好。
3,有一个点被染了两种色,图中出现环。环中任意两点x,y将会存在x->y,y->x。然后可证明,这时如果往这个环外多加一个点,在操作完成后也会满足任意两点x,y有x->y,y->x。即该联通块的边总数为点数的平方。
Code
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
int n,m,x,y;
struct node{int y,nxt,t;
}g[];int h[],tot=;
int cnt[],col[],_point,_link;
bool vis[],_is;
void dfs(int x)
{
cnt[col[x]]++;vis[x]=;_point++;
for(int i=h[x];i;i=g[i].nxt)
{
_link+=(g[i].t==);
if (!vis[g[i].y]) col[g[i].y]=(col[x]+g[i].t+)%,dfs(g[i].y);
else if (col[g[i].y]!=(col[x]+g[i].t+)%) _is=;
}
}
int main()
{
scanf("%d%d",&n,&m);
for (int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
g[++tot]=node{y,h[x],};h[x]=tot;
g[++tot]=node{x,h[y],-};h[y]=tot;
}
long long ans=;
for (int i=;i<=n;i++)
{
if (vis[i]) continue;
_is=;_point=_link=;cnt[]=cnt[]=cnt[]=;
dfs(i);
if (!_is) ans+=1ll*_point*_point;
else if (cnt[]&&cnt[]&&cnt[]) ans+=1ll*cnt[]*cnt[]+1ll*cnt[]*cnt[]+1ll*cnt[]*cnt[];
else ans+=_link;
}
printf("%lld",ans); }
[agc006F]Blackout的更多相关文章
- 2017国家集训队作业[agc006f]Blackout
2017国家集训队作业[agc006f]Blackout 题意: 有一个\(N*N\)的网格,一开始有\(M\)个格子被涂黑,给出这\(M\)个格子,和染色操作:如果有坐标为\((x,y),(y,z) ...
- [agc006f] Blackout 神题
Description 给你一个NN行NN列的网格,第ii行第jj列的格子用(i,j)(i,j)表示 一开始的时候有MM个格子被涂成黑色,其他的格子都是白色,具体一点,涂成黑色的格子为(a1,b1 ...
- [Atcoder Grand Contest 006 F][AGC006F] Blackout [染色]
题面 传送门 思路 首先,这个涂黑的方法我们来优化一下模型(毕竟当前这个放到矩形里面,你并看不出来什么规律qwq) 我们令每个行/列编号为一个点,令边(x,y)表示一条从x到y的有向边 那么显然只要有 ...
- NOIp模拟赛三十一
持续降智 分数:100+0+0=100 C题subtask是假的,根本没有部分分中的情况...还我20分QAQ A:[BZOJ4444]国旗计划 B:[agc006f]blackout C:[arc0 ...
- AtCoder刷题记录
构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...
- 【agc006f】Blackout(神仙题)
[agc006f]Blackout(神仙题) 翻译 给定一个\(n*n\)的网格图,有些格子是黑色的.如果\((x,y),(y,z)\)都是黑色的,那么\((y,x)\)也会被染黑,求最终黑格子数量. ...
- 【AGC006F】Blackout
Description 题目链接 Solution 首先,把输入矩阵看成邻接矩阵,将问题转化到图上. 现在的问题变成:给定一个有向图,如果存在\((u,v)\)和\((v,w)\),则连边\((w,u ...
- Atcoder2167 Blackout
Atcoder2167 Blackout zjoi讲过的一道神题啊... 首先把每个黑点(a,b)看成一条有向边a->b,然后这个图就变成了一张有自环的有向图. 然后弱联通块就分开了,对于每个连 ...
- UVA10600:ACM Contest and Blackout(次小生成树)
ACM Contest and Blackout 题目链接:https://vjudge.net/problem/UVA-10600 Description: In order to prepare ...
随机推荐
- C++ 异常处理机制的实现
http://blog.jobbole.com/103925/ 本文深入讨论了VC++编译器异常处理的实现机制.附件源代码包含了一个VC++的异常处理库. 下载源代码 – 19 Kb 介绍 相对于传统 ...
- BZOJ3175:[TJOI2013]攻击装置(二分图最大独立集)
Description 给定一个01矩阵,其中你可以在0的位置放置攻击装置.每一个攻击装置(x,y)都可以按照“日”字攻击其周围的 8个位置(x-1,y-2),(x-2,y-1),(x+1,y-2), ...
- 1295. [SCOI2009]最长距离【最短路】
Description windy有一块矩形土地,被分为 N*M 块 1*1 的小格子. 有的格子含有障碍物. 如果从格子A可以走到格子B,那么两个格子的距离就为两个格子中心的欧几里德距离. 如果从格 ...
- programming-languages学习笔记--第6部分
programming-languages学习笔记–第6部分 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} program ...
- 【bbs】login.php
require的路径 整体结构的复用 渐变效果的加入 按钮:实现背景透明,文字不透明:在background-color中使用rgba,标准浏览器中,背景透明,文字不透明background-colo ...
- 解决windows7无法连接CentOS7系统中oracle问题:ORA-12514 TNS 监听程序当前无法识别
linux开启后终端按下面输入(容易忘记,记录下): [oracle@localhost ~]$ lsnrctl stop #先关闭监听服务 [oracle@localh ...
- Eclipse设置working set管理项目
由于项目太多,看起来复杂,不容易找到,所以想要按文件夹区分,所以用到workingset. working set是把你这个存储空间的项目在eclipse中进行分类,只是在视图基础上分类,项目还是只有 ...
- eclipse安装activiti插件
参考: https://blog.csdn.net/augustaurora/article/details/59618737 https://blog.csdn.net/qq_33547950/ar ...
- iOS开发Mac配置(CocoaPods、SourceTree、ssh key)
作为开发,有一个自己的饭碗还是有必要的.因为交接旧电脑的时候,你会遇到了一些问题,而自己的电脑就方便很多了. 要开发,当然要装一些与开发相关的东西,那么新电脑入手,要做些什么呢? 1.安装Xcode: ...
- jquery toggleclass方法
给元素更改样式,一般使用 addClass() 和removeClass() jquery官方文档 对 addClass的介绍: Adds the specified class(es) to eac ...