Description

​ 给你一个NN行NN列的网格,第ii行第jj列的格子用(i,j)(i,j)表示

一开始的时候有MM个格子被涂成黑色,其他的格子都是白色,具体一点,涂成黑色的格子为(a1,b1),(a2,b2),(a3,b3)...(aM,bM)(a1,b1),(a2,b2),(a3,b3)...(aM,bM)

你的目标是按照以下规则将尽可能多的白色格子涂成黑色:如果存在三个格子(x,y)(x,y),(y,z)(y,z)和(z,x)(z,x)满足(x,y)(x,y)和(y,z)(y,z)都是黑格子并且(z,x)(z,x)是白格子(其中x,y,zx,y,z都是[1,N][1,N]之间的整数),那么你可以将(z,x)(z,x)涂成黑色

输出你不能继续操作时,黑格子的最大数量

Input

​ 第一行两个正整数N,MN,M

接下来MM行每行两个正整数(ai,bi)(ai,bi)表示一开始被涂成黑色的格子

Output

​ 共一行,一个整数ansans表示不能操作时黑格子的最大数量

Sample Input

#Sample1
3 2
1 2
2 3 #Sample2
2 2
1 1
1 2 #Sample3
4 3
1 2
1 3
4 4

Sample Output

#Sample1
3 #Sample2
4 #Sample3
3

HINT

数据范围:

​ 对于100%的数据,1<=N,M<=105,1<=ai,bi<=N1<=N,M<=105,1<=ai,bi<=N,并且所有的(ai,bi)(ai,bi)互不相同

样例解释:

​ Sample1:(1,2)(1,2)和(2,3)(2,3)都是黑的,可将白格(3,1)(3,1)涂成白色

​ Sample2:(1,1)(1,1)和(1,2)(1,2)都是黑的,可将白格(2,1)(2,1)涂成黑色;接着(2,1)(2,1)和(1,2)(1,2)都是黑的,可将白格(2,2)(2,2)涂成黑色

​ Sample3:无法操作

Sol

对于每个黑色点,我们直接连边x-y,然后发现距离为3的点可以产生贡献的边。

为了处理这个问题,我们对图进行012染色,x-y连距离1,y-x连距离2,根据距离mod3决定染得颜色,之后0-1,1-2,2-0都是合法的变黑的方案。。。答案为\(c0*c1+c1*c2+c2*c0\)。

假设染色出现环,画个图就知道所有点都能互相连边,所以答案是\(size^2\)。

如果根本染不满,就是原来的数量。。。

其实上面讲的不是核心思想。。。核心思想之有第一句,后面的只是一种高效简洁的实现方法。。。

Code

#include <bits/stdc++.h>
using namespace std;
int n,m,x,y,col[100005],cnt[5],ok;long long ans;vector<pair<int,int> >e[100005];
void dfs(int x)
{
cnt[col[x]]++;
for(int i=0;i<e[x].size();i++)
{
if(e[x][i].second==1) cnt[3]++;
if(col[e[x][i].first]==-1) col[e[x][i].first]=(col[x]+e[x][i].second)%3,dfs(e[x][i].first);
else if((col[x]+e[x][i].second)%3!=col[e[x][i].first]) ok=1;
}
}
int main()
{
scanf("%d%d",&n,&m);memset(col,-1,sizeof(col));
for(int i=1;i<=m;i++) scanf("%d%d",&x,&y),e[x].push_back(make_pair(y,1)),e[y].push_back(make_pair(x,2));
for(int i=1;i<=n;i++) if(col[i]==-1)
{
memset(cnt,0,sizeof(cnt));ok=col[i]=0;dfs(i);
if(ok){ans+=1ll*(cnt[0]+cnt[1]+cnt[2])*(cnt[0]+cnt[1]+cnt[2]);continue;}
else if((!cnt[0])||(!cnt[1])||(!cnt[2])){ans+=1ll*cnt[3];continue;}
else ans+=1ll*cnt[0]*cnt[1]+1ll*cnt[1]*cnt[2]+1ll*cnt[2]*cnt[0];
}
printf("%lld\n",ans);
}

[agc006f] Blackout 神题的更多相关文章

  1. 2017国家集训队作业[agc006f]Blackout

    2017国家集训队作业[agc006f]Blackout 题意: 有一个\(N*N\)的网格,一开始有\(M\)个格子被涂黑,给出这\(M\)个格子,和染色操作:如果有坐标为\((x,y),(y,z) ...

  2. POJ 2484 A Funny Game(神题!)

    一开始看这道博弈题的时候我就用很常规的思路去分析了,首先先手取1或者2个coin后都会使剩下的coin变成线性排列的长条,然后无论双方如何操作都是把该线条分解为若干个子线条而已,即分解为若干个子游戏而 ...

  3. BUAA 724 晴天小猪的神题(RMQ线段树)

    BUAA 724 晴天小猪的神题 题意:中文题,略 题目链接:http://acm.buaa.edu.cn/problem/724/ 思路:对于询问x,y是否在同一区间,可以转换成有没有存在一个区间它 ...

  4. Bzoj 4408: [Fjoi 2016]神秘数 可持久化线段树,神题

    4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 177  Solved: 128[Submit][Status ...

  5. 【CF913F】Strongly Connected Tournament 概率神题

    [CF913F]Strongly Connected Tournament 题意:有n个人进行如下锦标赛: 1.所有人都和所有其他的人进行一场比赛,其中标号为i的人打赢标号为j的人(i<j)的概 ...

  6. [agc007f] Shik and Copying String 模拟神题

    Description ​ "全"在十分愉快打工,第0天,给了他一个仅有小写字母构成的长度为N的字符串S0,在之后的第i天里,"全"的工作是将Si−1复制一份到 ...

  7. AtCoder 神题汇总

    记录平时打 AtCoder 比赛时遇到的一些神题. Tenka1 Programmer Contest 2019 D Three Colors 题目大意 有 $n$ 个正整数 $a_1, a_2,\d ...

  8. hdoj5821【贪心-神题】

    啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊,比赛的时候直接读错题了,实力带坑队友.... 题意: 有两个序列都代表筐,每个筐里只有一个球,然后序列的值代表筐里的球的颜色,问你在m次操作后,a序列的球能否变成b ...

  9. [Bzoj4817] [Sdoi2017]树点涂色 (LCT神题)

    4817: [Sdoi2017]树点涂色 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 629  Solved: 371[Submit][Status ...

随机推荐

  1. gzip是一种数据格式,deflate是一种压缩算法

    gzip是一种数据格式,默认且目前仅使用deflate算法压缩data部分:deflate是一种压缩算法,是huffman编码的一种加强. deflate与gzip解压的代码几乎相同,可以合成一块代码 ...

  2. sqlserver: 使用While 示例

    declare @i intset @i = 1999while(@i<2009)begin declare @sql varchar(8000) set @sql = 'update    d ...

  3. proxmox 去除订阅提示

    去掉登陆时是否订阅通知修改文件   /usr/share/javascript/proxmox-widget-toolkit/proxmoxlib.js 搜索关键字  “You do not have ...

  4. 机器学习算法中GBDT和XGBOOST的区别有哪些

    首先xgboost是Gradient Boosting的一种高效系统实现,并不是一种单一算法.xgboost里面的基学习器除了用tree(gbtree),也可用线性分类器(gblinear).而GBD ...

  5. win10如和设置远程桌面

    最近几天一直在搞远程桌面问题,电脑一直连不上远程,今天终于出来了. 前提前提  条件,要电脑允许Administrator用户,先把电脑切换到那个用户,然后进行下面操作. 1.在桌面,我的电脑图标,鼠 ...

  6. How to Restart Qt Application

    How to restart QtApplication As we know, Restarting Application means to exit current application, t ...

  7. 数据结构notes

    1. 一份很好的数据结构教程,图文并茂,简明扼要,列出每种结构的定义和优缺点,非常适合初学者 via @ranyif https://www.interviewcake.com/data-struct ...

  8. MySQL之——GROUP BY分组取字段最大值

    转载自:http://blog.csdn.net/l1028386804/article/details/54657412 假设有一个业务场景,需要查询用户登录记录信息,其中表结构如下: CREATE ...

  9. Python之Scrapy遇见个坑

    运行Scrapy爬虫被限制抓取,报错: -- :: [scrapy.middleware] INFO: Enabled item pipelines: [] -- :: [scrapy.core.en ...

  10. [Selenium] Java代码获取,设置屏幕分辨率

    import java.awt.Dimension; import java.awt.DisplayMode; import java.awt.GraphicsDevice; import java. ...