hdu2242 考研路茫茫——空调教室
弱联通
#include<iostream>
#include<cstdio>
#include<cstring>
#include<map>
#include<cmath>
#include<queue>
#include<stack>
#include<vector>
#define inf 0x3f3f3f3f
#define N 10005
#define M 40005
typedef long long LL;
using namespace std;
stack<int>st;
int value[N];
struct Node{
int to,next;
}edge[M];
int tol,head[N];
struct rNode{
int to,next;
}redge[M];
int rtol,rhead[N];
void addedge(int u,int v){
edge[tol].to=v; edge[tol].next=head[u]; head[u]=tol++;
}
void raddedge(int u,int v){
redge[rtol].to=v; redge[rtol].next=rhead[u]; rhead[u]=rtol++;
}
int Belong[N],val[N],visit[N],Low[N],Dfn[N],cnt,scc,Ans,Sum; void Tarjan(int x,int father){
int i,j,flag=0;
Low[x]=Dfn[x]=cnt++;
visit[x]=1;
st.push(x);
for(i=head[x];i!=-1;i=edge[i].next){
int y=edge[i].to;
if(y==father && !flag) { flag=1; continue; }
if(!visit[y]) Tarjan(y,x);
Low[x]=min(Low[x],Low[y]);
}
if(Dfn[x]==Low[x]){
scc++; int v;
do{
v=st.top();
st.pop();
Belong[v]=scc;
val[scc]+=value[v];
}while(v!=x);
}
}
int Min(int a,int b){
if(a>b) return b;
return a;
}
int dfs(int x,int father){
int i,j;
int sum=val[x];
for(i=rhead[x];i!=-1;i=redge[i].next){
int y=redge[i].to;
if(y==father) continue;
sum+=dfs(y,x);
}
Ans=Min(Ans,abs(Sum-sum*2));
return sum;
}
int main(){
int n,m;
int i,j,k;
while(~scanf("%d %d",&n,&m)){
Sum=0;
tol=rtol=cnt=scc=0;
memset(head,-1,sizeof(head));
memset(rhead,-1,sizeof(rhead));
memset(visit,0,sizeof(visit));
memset(val,0,sizeof(val));
for(i=0;i<n;i++){
scanf("%d",&value[i]); Sum+=value[i];
}
for(i=0;i<m;i++){
int a,b; scanf("%d %d",&a,&b);
addedge(a,b); addedge(b,a);
}
Tarjan(0,0);
//for(i=0;i<n;i++) printf("%d %d\n",i,Belong[i]);
if(scc==1) {
printf("impossible\n"); continue;
}
for(i=0;i<n;i++)
for(j=head[i];j!=-1;j=edge[j].next){
int t1=Belong[i]; int t2=Belong[edge[j].to];
if(t1!=t2) raddedge(t1,t2);
}
Ans=inf;
dfs(1,0);
printf("%d\n",Ans);
}
return 0;
}
/*
【题意】
一个无向连通图 每个点有个值 求断开一条边使得形成两个联通图
并使两边的 点和之差 最小 【做法】
弱联通缩点 之后dfs即可 【思考】
第一写弱联通 学到了 */
hdu2242 考研路茫茫——空调教室的更多相关文章
- HDU2242 考研路茫茫——空调教室 (双联通分+树形DP)
考研路茫茫——空调教室 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 2242 考研路茫茫——空调教室 无向图缩环+树形DP
考研路茫茫——空调教室 Problem Description 众所周知,HDU的考研教室是没有空调的,于是就苦了不少不去图书馆的考研仔们.Lele也是其中一个.而某教室旁边又摆着两个未装上的空调,更 ...
- HDU 2242 考研路茫茫----空调教室
传送门 考研路茫茫——空调教室 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- HDU 2242 考研路茫茫——空调教室
考研路茫茫——空调教室 http://acm.hdu.edu.cn/showproblem.php?pid=2242 分析: 树形dp,删边. 代码: #include<cstdio> # ...
- HDU 2242 考研路茫茫——空调教室(边双连通)
HDU 2242 考研路茫茫--空调教室 题目链接 思路:求边双连通分量.然后进行缩点,点权为双连通分支的点权之和,缩点完变成一棵树,然后在树上dfs一遍就能得出答案 代码: #include < ...
- 考研路茫茫——空调教室HDU2242(Tarjan缩点)
题意:http://acm.hdu.edu.cn/showproblem.php?pid=2242 给你一个图,问你缩完点树上割边的做小绝对值差. 思路: 这题核算起来整整做了我一天(即24个小时)! ...
- 【HDOJ】2242 考研路茫茫——空调教室
tarjan缩点,然后树形dp一下可解.重点是重边的处理. /* 2242 */ #include <iostream> #include <sstream> #include ...
- HDU 2242 考研路茫茫—空调教室 (边双连通+树形DP)
<题目链接> 题目大意: 给定一个连通图,每个点有点权,现在需要删除一条边,使得整张图分成两个连通块,问你删除这条边后,两联通块点权值和差值最小是多少. 解题分析: 删除一条边,使原连通图 ...
- HDU 2242 考研路茫茫——空调教室(边双连通分量+树形dp+重边标号)
http://acm.hdu.edu.cn/showproblem.php?pid=2242 题意: 思路:首先求一下双连通分量,如果只有一个双连通分量,那么无论断哪根管子,图还是连通的. 最后只需要 ...
随机推荐
- 使用hbase小结
背景 hbase中一张表的rowkey定义为时间戳+字符串 需求 根据时间戳和列簇中某列的值为"abc",导出一天内的数据到excel中. 使用FilterList FilterL ...
- MySQL实现差集(Minus)和交集(Intersect)
原文链接: http://www.linuxidc.com/Linux/2014-06/103551.htm MySQL没有实现Minus和Intersect功能,就像它也没有实现cube的功能一样. ...
- BZOJ 2005: [Noi2010]能量采集 [莫比乌斯反演]
题意:\((0,0)\)到\((x,y),\ x \le n, y \le m\)连线上的整点数\(*2-1\)的和 \((0,0)\)到\((a,b)\)的整点数就是\(gcd(a,b)\) 因为. ...
- Azure Automation (6) 执行Azure SQL Job
<Windows Azure Platform 系列文章目录> 因为China Azure SQL Database目前还没有SQL Job的功能,如果要异步执行SQL 存储过程,可以使用 ...
- R语言-选择样本数量
功效分析:可以帮助在给定置信度的情况下,判断检测到给定效应值时所需的样本量,也可以在给定置信水平的情况下,计算某样本量内可以检测到的给定效应值的概率 1.t检验 案例:使用手机和司机反应时间的实验 l ...
- 如何解决JavaScript中0.1+0.2不等于0.3
console.log(0.1+0.2===0.3)// true or false?? 在正常的数学逻辑思维中,0.1+0.2=0.3这个逻辑是正确的,但是在JavaScript中0.1+0.2!= ...
- Orleans例子源码
这是Orleans系列文章中的一篇.首篇文章在此 我共享以下我现在写教程的简单的Orleans例子源码. 这个代码已经是我为了写word改动过了的.不过大体内容是通用的. 我写博客总体想法是:去除所有 ...
- 从此不再担心键盘遮住输入框OC(一)
文/Jiar_(简书作者)原文链接:http://www.jianshu.com/p/48993ff982c1著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 新版本在这里:从此不再担心 ...
- linux 中 svn 服务器搭建 重启
鉴于在搭建时,参考网上很多资料,网上资料在有用的同时,也坑了很多人 本文的目的,也就是想让后继之人在搭建svn服务器时不再犯错,不再被网上漫天的坑爹作品所坑害,故此总结 /******开始****** ...
- ASP.NET Core的身份认证框架IdentityServer4--(2)API跟WEB端配置
API配置 可以使用ASP.NET Core Web API模板.同样,我们建议您控制端口并使用与之前一样的方法来配置Kestrel和启动配置文件.端口配置为http://localhost:5001 ...