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); }

最新文章

  1. xpath定位中starts-with、contains和text()的用法
  2. 深入学习jQuery选择器系列第七篇——表单选择器
  3. SQL Server调优系列玩转篇三(利用索引提示(Hint)引导语句最大优化运行)
  4. 常用的phpstorm设置
  5. .NET多线程执行函数
  6. NVCC编译器
  7. 总结的git操作命令小抄集
  8. cdn是什么
  9. oracle用户、权限操作
  10. cent os 7 与cent os 6区别
  11. iis7.5 配置伪静态
  12. iOS学习——(转)UIResponder详解
  13. Setting up Scatter for Web Applications
  14. ModBus通信协议的【Modbus RTU 协议使用汇总】
  15. js-变量定义关键字const,var,let
  16. 1-AO3402MOS管使用
  17. 使用Messenger 从Activity发送数据到service 通过后台计算结果Log输出;
  18. cloneNode
  19. thinkphp中的验证器
  20. ubuntu无法获得锁 /var/lib/dpkg -open 问题

热门文章

  1. Hive安装报错
  2. Eclipse 连接真实机器调试
  3. 关于crontab中的一些小问题
  4. apache2 重启、停止、优雅重启、优雅停止
  5. 通过 lsyncd + rsync 同步文件
  6. 5 个强大的 HTML5 API
  7. Jquery mobile 自定义 返回按钮 data-rel=&quot;back&quot;
  8. OpenGL之位图的绘制和gluOrtho2D等函数详解
  9. docker启动容器关于防火墙报错
  10. utils.js文件;一些常用方法的备份