hdu 4635 Strongly connected 强连通缩点
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4635
题意:给你一个n个点m条边的图,问在图不是强连通图的情况下,最多可以向图中添多少条边,若图为原来就是强连通图,输出-1即可;
思路:最后得到的图肯定分为两部分x和y,且两部分均为强连通分量,要么x的点到y的所有点有边,要么,从y的所有点到x的所有点有边;(其中只有入度或出度为0的点才可能成为x或y)
则有 x+y=n
答案为 ans = y*(y-1) + x*(x-1)+ y*x - m;
化简后 ans = n*n - n -n*x - x*x - m;
由以上化简试,x越小,ans值越大(答案最多为一百亿,long long 之)
#include "stdio.h" //hdu 4635 强连通缩点
#include "string.h"
#include "vector"
#include "stack"
using namespace std; #define N 201000
#define INF 0x3fffffff long long n,m;
int time;
stack<int> q;
int dfn[N],low[N];
int MIN(int x,int y) { return x<y?x:y; }
long long MAX(long long x,long long y) { return x>y?x:y; } struct node
{
int x,y;
int next;
}edge[2*N];
int idx,head[N]; bool vis[N]; void Init()
{
idx=0;
memset(head,-1,sizeof(head));
} void Add(int x,int y)
{
edge[idx].x = x;
edge[idx].y = y;
edge[idx].next = head[x];
head[x] = idx++;
} int countt; //统计缩点个数
int num[N]; //统计每个缩点内的点的个数
int ru_du[N],chu_du[N]; //统计缩点的出,入度
int belong[N]; //标记点属于哪个缩点 void DFS(int x)
{
int i,y;
q.push(x);
vis[x] = true;
dfn[x] = low[x] = ++time;
for(i=head[x]; i!=-1; i=edge[i].next)
{
y = edge[i].y;
if(!dfn[y])
{
DFS(y);
low[x] = MIN(low[x],low[y]);
}
else if(vis[y]) //强双连通图出现的新判断条件
low[x] = MIN(dfn[y],low[x]);
}
if(low[x]==dfn[x])
{
int temp;
countt++;
while(1)
{
temp = q.top();
q.pop();
belong[temp] = countt;
num[countt]++;
vis[temp] = false; //还原了~
if(temp==x) break;
}
}
} long long Solve()
{
int i;
int x,y;
time = countt = 0;
memset(dfn,0,sizeof(dfn));
memset(num,0,sizeof(num));
memset(belong,0,sizeof(belong));
memset(vis,false,sizeof(vis));
for(i=1; i<=n; ++i)
{
if(!dfn[i])
DFS(i);
}
if(countt==1) return -1;
memset(ru_du,0,sizeof(ru_du));
memset(chu_du,0,sizeof(chu_du));
for(i=0; i<idx; ++i)
{
x = edge[i].x;
y = edge[i].y;
if(belong[x]!=belong[y])
{
chu_du[belong[x]]++;
ru_du[belong[y]]++;
}
}
long long ans=0,mint;
for(i=1; i<=countt; ++i)
{
if(chu_du[i]==0 || ru_du[i]==0){
mint = num[i];
ans = MAX(ans,n*n-n-mint*(n-mint)-m);
}
}
return ans;
} int main()
{
int T,Case=0;
int i;
int x,y;
scanf("%d",&T);
while(T--)
{
Init();
Case++;
scanf("%lld %lld",&n,&m);
for(i=0; i<m; ++i)
{
scanf("%d %d",&x,&y);
Add(x,y);
}
printf("Case %d: ",Case);
printf("%lld\n",Solve());
}
}
hdu 4635 Strongly connected 强连通缩点的更多相关文章
- HDU 4635 Strongly connected(强连通)经典
		
Strongly connected Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
 - HDU 4635 Strongly connected (强连通分量+缩点)
		
<题目链接> 题目大意: 给你一张有向图,问在保证该图不能成为强连通图的条件下,最多能够添加几条有向边. 解题分析: 我们从反面思考,在该图是一张有向完全图的情况下,最少删去几条边能够使其 ...
 - HDU 4635 Strongly connected (强连通分量)
		
题意 给定一个N个点M条边的简单图,求最多能加几条边,使得这个图仍然不是一个强连通图. 思路 2013多校第四场1004题.和官方题解思路一样,就直接贴了~ 最终添加完边的图,肯定可以分成两个部X和Y ...
 - hdu 4635 Strongly connected   强连通
		
题目链接 给一个有向图, 问你最多可以加多少条边, 使得加完边后的图不是一个强连通图. 只做过加多少条边变成强连通的, 一下子就懵逼了 我们可以反过来想. 最后的图不是强连通, 那么我们一定可以将它分 ...
 - HDU 4635 —— Strongly connected——————【 强连通、最多加多少边仍不强连通】
		
Strongly connected Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u ...
 - HDU 4635 Strongly connected (2013多校4  1004  有向图的强连通分量)
		
Strongly connected Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
 - hdu 4635	Strongly connected(强连通)
		
考强连通缩点,算模板题吧,比赛的时候又想多了,大概是不自信吧,才开始认真搞图论,把题目想复杂了. 题意就是给你任意图,保证是simple directed graph,问最多加多少条边能使图仍然是si ...
 - HDU 4635 Strongly connected (Tarjan+一点数学分析)
		
Strongly connected Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) ...
 - HDU 4635 Strongly connected(强连通分量缩点+数学思想)
		
题意:给出一个图,如果这个图一开始就不是强连通图,求出最多加多少条边使这个图还能保持非强连通图的性质. 思路:不难想到缩点转化为完全图,然后找把它变成非强连通图需要去掉多少条边,但是应该怎么处理呢…… ...
 
随机推荐
- 控制器中的Action方法,接收浏览器传过来的参数,总共有几种?
			
1.根据配置文件中的URL规则 public ActionResult Delete(int id) //id参数就是根据路由里面的参数id来传过来的,这个action方法中的参数一定要和路由中的id ...
 - 2014 Asia AnShan Regional Contest --- HDU 5078 Osu!
			
Osu! Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5078 Mean: 略. analyse: 签到题,直接扫一遍就得答 ...
 - MEF核心笔记(6)让 MEF 拥抱 AOP
			
场景: 最近推荐同事在项目中使用起了 MEF,用其构建一个插件式的多人开发框架,因为该框架不是让我去设计了,所以对于 MEF 和 IOC 等概念不是很了解的同事,便会出现各种问题.接入 AOP 便是其 ...
 - 改造一下C# Substring()函数
			
C#的Substring()函数中,如果我们一不小心输入一个截取长度大于字符串的长时,就会收到一个异常:startIndex cannot be larger than length of strin ...
 - Mantis 缺陷管理系统配置与安装
			
什么是Mantis MantisBT is a free popular web-based bugtracking system (feature list). It is written in t ...
 - trie树---(插入、删除、查询字符串)
			
HDU 5687 Problem Description 度熊手上有一本神奇的字典,你可以在它里面做如下三个操作: 1.insert : 往神奇字典中插入一个单词 2.delete: 在神奇字 ...
 - 泛函编程(17)-泛函状态-State In Action
			
对OOP编程人员来说,泛函状态State是一种全新的数据类型.我们在上节做了些介绍,在这节我们讨论一下State类型的应用:用一个具体的例子来示范如何使用State类型.以下是这个例子的具体描述: 模 ...
 - [译] 你应该升级 MQTT3.1.1 的6个理由
			
原文 6 facts why it’s worth upgrading to the brand new MQTT 3.1.1version 摘要:新版 MQTT 3.1.1 终于在 2014 年 1 ...
 - c#泛型方法返回null的问题
			
c#的泛型方法实现和java实现有点不同,在java中,所有的泛型方法运行时类型必须是引用类型,所以和非泛型一样可以返回null. 但是c#中有点不同,可以同时是值类型和引用类型,而值类型不能赋值nu ...
 - JavaScript一个经典问题
			
看下面代码 <ul id="demo"> <li></li> <li></li> <li></li&g ...