2768: [JLOI2010]冠军调查

题目连接:

http://www.lydsy.com/JudgeOnline/problem.php?id=2768

Description

一年一度的欧洲足球冠军联赛已经进入了淘汰赛阶段。随着卫冕冠军巴萨罗那的淘汰,英超劲旅切尔西成为了头号热门。新浪体育最近在吉林教育学院进行了一次大规模的调查,调查的内容就是关于切尔西能否在今年问鼎欧洲冠军。新浪体育的记者从各个院系中一共抽取了n位同学作为参与者,大家齐聚一堂,各抒己见。每一位参与者都将发言,阐述自己的看法。参与者的心里都有一个看法,比如FireDancer认为切尔西不可能夺冠,而WaterDancer认为切尔西一定问鼎。但是因为WaterDancer是FireDancer的好朋友,所以可能FireDancer为了迁就自己的好朋友,会在发言中支持切尔西。也就是说每个参与者发言时阐述的看法不一定就是心里所想的。现在告诉你大家心里的想法和参与者的朋友网,希望你能安排每个人的发言内容,使得违心说话的人的总数与发言时立场不同的朋友(对)的总数的和最小。

Input

第一行两个整数n和m,其中n(2≤n≤300)表示参与者的总数,m(0≤m≤n(n-1)/2)表示朋友的总对数。

第二行n个整数,要么是0要么是1。如果第i个整数的值是0的话,表示第i个人心里认为切尔西将与冠军无缘,如果是1的话,表示他心里认为切尔西必将夺魁。

下面m行每行两个不同的整数,i和j(1≤i, j≤n)表示i和j是朋友。注意没有一对朋友会在输入中重复出现。朋友关系是双向的,并且不会传递。

Output

只有一个整数,为最小的和

Sample Input

3 3

1 0 0

1 2

1 3

2 3

Sample Output

1

Hint

最好的安排是所有人都在发言时说切尔西不会夺冠。这样没有一对朋友的立场相左,只有第1个人他违心说了话。

题意

题解:

最小割模型

就是你要么割掉这个人,要么就割掉这个人和他朋友的边

然后跑一波最大流就好了

代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int MAXN=1000000,MAXM=1000000,inf=1e9;
  4. struct Edge
  5. {
  6. int v,c,f,nx;
  7. Edge() {}
  8. Edge(int v,int c,int f,int nx):v(v),c(c),f(f),nx(nx) {}
  9. } E[MAXM];
  10. int G[MAXN],cur[MAXN],pre[MAXN],dis[MAXN],gap[MAXN],N,sz;
  11. void init(int _n)
  12. {
  13. N=_n,sz=0; memset(G,-1,sizeof(G[0])*N);
  14. }
  15. void link(int u,int v,int c)
  16. {
  17. E[sz]=Edge(v,c,0,G[u]); G[u]=sz++;
  18. E[sz]=Edge(u,0,0,G[v]); G[v]=sz++;
  19. }
  20. bool bfs(int S,int T)
  21. {
  22. static int Q[MAXN]; memset(dis,-1,sizeof(dis[0])*N);
  23. dis[S]=0; Q[0]=S;
  24. for (int h=0,t=1,u,v,it;h<t;++h)
  25. {
  26. for (u=Q[h],it=G[u];~it;it=E[it].nx)
  27. {
  28. if (dis[v=E[it].v]==-1&&E[it].c>E[it].f)
  29. {
  30. dis[v]=dis[u]+1; Q[t++]=v;
  31. }
  32. }
  33. }
  34. return dis[T]!=-1;
  35. }
  36. int dfs(int u,int T,int low)
  37. {
  38. if (u==T) return low;
  39. int ret=0,tmp,v;
  40. for (int &it=cur[u];~it&&ret<low;it=E[it].nx)
  41. {
  42. if (dis[v=E[it].v]==dis[u]+1&&E[it].c>E[it].f)
  43. {
  44. if (tmp=dfs(v,T,min(low-ret,E[it].c-E[it].f)))
  45. {
  46. ret+=tmp; E[it].f+=tmp; E[it^1].f-=tmp;
  47. }
  48. }
  49. }
  50. if (!ret) dis[u]=-1; return ret;
  51. }
  52. int dinic(int S,int T)
  53. {
  54. int maxflow=0,tmp;
  55. while (bfs(S,T))
  56. {
  57. memcpy(cur,G,sizeof(G[0])*N);
  58. while (tmp=dfs(S,T,inf)) maxflow+=tmp;
  59. }
  60. return maxflow;
  61. }
  62. int main()
  63. {
  64. init(900000);
  65. int n,m;
  66. scanf("%d%d",&n,&m);
  67. int s = 0,t = n+2;
  68. for(int i=1;i<=n;i++)
  69. {
  70. int x;scanf("%d",&x);
  71. if(x)link(s,i,1);
  72. else link(i,t,1);
  73. }
  74. for(int i=1;i<=m;i++)
  75. {
  76. int x,y;scanf("%d%d",&x,&y);
  77. link(x,y,1);
  78. link(y,x,1);
  79. }
  80. printf("%d\n",dinic(s,t));
  81. }

BZOJ 2768: [JLOI2010]冠军调查 最小割的更多相关文章

  1. 2768: [JLOI2010]冠军调查( 最小割 )

    最小割... 怎么乱搞都可以 -------------------------------------------------------------------------------- #inc ...

  2. bzoj 2768: [JLOI2010]冠军调查

    #include<cstdio> #include<iostream> #define M 100000 #include<cstring> using names ...

  3. JLOI2010 冠军调查 最小割

    var b,f:..] of longint; s,t,i,j,n,m,x,y:longint; l,h:..]of longint; a:..,..]of longint; procedure bf ...

  4. 【BZOJ-2768】冠军调查 最小割

    2768: [JLOI2010]冠军调查 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 971  Solved: 661[Submit][Status ...

  5. BZOJ-2768: [JLOI2010]冠军调查(超级裸的最小割)

    2768: [JLOI2010]冠军调查 Time Limit: 10 Sec  Memory Limit: 128 MB Description 一年一度的欧洲足球冠军联赛已经进入了淘汰赛阶段.随着 ...

  6. bzoj2768: [JLOI2010]冠军调查(双倍经验最小割)

    2768: [JLOI2010]冠军调查 题目:传送门 题解: 双倍经验(1934) 代码: #include<cstdio> #include<cstring> #inclu ...

  7. BZOJ2768: [JLOI2010]冠军调查

    2768: [JLOI2010]冠军调查 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 484  Solved: 332[Submit][Status ...

  8. 【BZOJ2768】[JLOI2010]冠军调查/【BZOJ1934】[Shoi2007]Vote 善意的投票 最小割

    [BZOJ2768][JLOI2010]冠军调查 Description 一年一度的欧洲足球冠军联赛已经进入了淘汰赛阶段.随着卫冕冠军巴萨罗那的淘汰,英超劲旅切尔西成为了头号热门.新浪体育最近在吉林教 ...

  9. P2057 [SHOI2007]善意的投票 / [JLOI2010]冠军调查

    P2057 [SHOI2007]善意的投票 / [JLOI2010]冠军调查 拿来练网络流的qwq 思路:如果i不同意,连边(i,t,1),否则连边(s,i,1).好朋友x,y间连边(x,y,1)(y ...

随机推荐

  1. jquery、js操作checkbox全选反选

    全选反选checkbox在实际应用中比较常见,本文有个不错的示例,大家可以参考下 操作checkbox,全选反选//全选 function checkAll() { $('input[name=&qu ...

  2. python中的深拷贝与浅拷贝

    深拷贝和浅拷贝 浅拷贝的时候,修改原来的对象,浅拷贝的对象不会发生改变. 1.对象的赋值 对象的赋值实际上是对象之间的引用:当创建一个对象,然后将这个对象赋值给另外一个变量的时候,python并没有拷 ...

  3. 谈谈final、finally和finalize

    final: final为修饰符, 如果类被声明为final,则不能派生新子类. 如果变量被声明为final,则必须在声明时初始化,在以后的引用只能读取,不可修改. 如果方法被final声明,则只能使 ...

  4. gcc都做了什么优化

    直接上程序: setjmp和longjmp是处理函数嵌套调用的,goto语句不能跨越函数,所以不选择goto. #include <setjmp.h> int setjmp(jmp_buf ...

  5. awk与sed简明教程

    看到大牛写的关于awk和sed的简明教程,写得很好,为了尊重作者,就不全文转载了,这里标记下链接,方便以后查阅. awk简明教程:http://coolshell.cn/articles/9070.h ...

  6. manacher算法_求最长回文子串长度

    很好的总结,转自: http://blog.csdn.net/dyx404514/article/details/42061017 总结为:两大情况,三小情况. 两大情况:I. i <= p 1 ...

  7. [转]对Android开发者有益的40条优化建议

    下面是开始Android编程的好方法: 找一些与你想做事情类似的代码 调整它,尝试让它做你像做的事情 经历问题 使用StackOverflow解决问题 对每个你像添加的特征重复上述过程.这种方法能够激 ...

  8. 数据结构(11) -- 邻接表存储图的DFS和BFS

    /////////////////////////////////////////////////////////////// //图的邻接表表示法以及DFS和BFS //////////////// ...

  9. extjs笔记

      1.    ExtJs 结构树.. 2 2.    对ExtJs的态度.. 3 3.    Ext.form概述.. 4 4.    Ext.TabPanel篇.. 5 5.    Functio ...

  10. poj 3006 Dirichlet's Theorem on Arithmetic Progressions

    题目大意:a和d是两个互质的数,则序列a,a+d,a+2d,a+3d,a+4d ...... a+nd 中有无穷多个素数,给出a和d,找出序列中的第n个素数 #include <cstdio&g ...