Description
幼儿园里有n个小朋友打算通过投票来决定睡不睡午觉。对他们来说,这个问题并不是很重要,于是他们决定发扬谦让精神。虽然每个人都有自己的主见,但是为了照顾一下自己朋友的想法,他们也可以投和自己本来意愿相反的票。我们定义一次投票的冲突数为好朋友之间发生冲突的总数加上和所有和自己本来意愿发生冲突的人数。 我们的问题就是,每位小朋友应该怎样投票,才能使冲突数最小?
Input
第一行只有两个整数n,m,保证有2≤n≤300,1≤m≤n(n-1)/2。其中n代表总人数,m代表好朋友的对数。文件第二行有n个整数,第i个整数代表第i个小朋友的意愿,当它为1时表示同意睡觉,当它为0时表示反对睡觉。接下来文件还有m行,每行有两个整数i,j。表示i,j是一对好朋友,我们保证任何两对i,j不会重复。
Output
只需要输出一个整数,即可能的最小冲突数。
Sample Input
3 3
1 0 0
1 2
1 3
3 2
Sample Output
1
HINT

在第一个例子中,所有小朋友都投赞成票就能得到最优解

经典的最小割模型,见算法合集之《最小割模型在信息学竞赛中的应用》.pdf

本来的意愿就是固定的点,然后每个都是不确定的点

从s向固定的0连容量inf的边,从固定的1向t连容量inf的边

从固定的0向自己对应的节点连容量1的边,从对应的节点向固定的1连容量1的边

朋友之间就互相连容量1的边

很囧的建错了两次图

1.固定的点我只连了容量1的边

2.固定的0和1向每个节点都连了边

但是有90分,应该是因为每个人都选同一种代价小于n吧(这个90分好奇葩的样子)

  1. const
  2. maxn=;
  3. inf=;
  4. var
  5. map:array[..maxn,..maxn]of longint;
  6. n,m,s,t:longint;
  7.  
  8. procedure init;
  9. var
  10. i,x,y:longint;
  11. begin
  12. read(n,m);
  13. s:=;
  14. t:=n*+;
  15. for i:= to n do
  16. begin
  17. read(x);
  18. if x= then
  19. begin
  20. map[s,i+n]:=inf;
  21. map[i+n,i]:=;
  22. end
  23. else
  24. begin
  25. map[i+n,t]:=inf;
  26. map[i,i+n]:=;
  27. end;
  28. end;
  29. for i:= to m do
  30. begin
  31. read(x,y);
  32. map[x,y]:=;
  33. map[y,x]:=;
  34. end;
  35. end;
  36.  
  37. var
  38. dis,vh,pre,his:array[..maxn]of longint;
  39. flow,aug:longint;
  40.  
  41. procedure sap;
  42. var
  43. i,j,min:longint;
  44. flag:boolean;
  45. begin
  46. vh[]:=t+;
  47. i:=s;
  48. aug:=inf;
  49. while dis[i]<=t do
  50. begin
  51. his[i]:=aug;
  52. flag:=false;
  53. for j:=s to t do
  54. if (map[i,j]>) and (dis[i]=dis[j]+) then
  55. begin
  56. flag:=true;
  57. if aug>map[i,j] then aug:=map[i,j];
  58. pre[j]:=i;
  59. i:=j;
  60. if i=t then
  61. begin
  62. inc(flow,aug);
  63. while i<>s do
  64. begin
  65. inc(map[i,pre[i]],aug);
  66. dec(map[pre[i],i],aug);
  67. i:=pre[i];
  68. end;
  69. aug:=inf;
  70. end;
  71. break;
  72. end;
  73. if flag then continue;
  74. min:=t;
  75. for j:=s to t do
  76. if (map[i,j]>) and (dis[j]<min) then min:=dis[j];
  77. dec(vh[dis[i]]);
  78. if vh[dis[i]]= then break;
  79. dis[i]:=min+;
  80. inc(vh[min+]);
  81. if i<>s then
  82. begin
  83. i:=pre[i];
  84. aug:=his[i];
  85. end;
  86. end;
  87. writeln(flow);
  88. end;
  89.  
  90. begin
  91. init;
  92. sap;
  93. end.

1934: [Shoi2007]Vote 善意的投票 - BZOJ的更多相关文章

  1. BZOJ 1934: [Shoi2007]Vote 善意的投票 最小割

    1934: [Shoi2007]Vote 善意的投票 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnl ...

  2. 1934: [Shoi2007]Vote 善意的投票

    1934: [Shoi2007]Vote 善意的投票 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 1174  Solved: 723[Submit][S ...

  3. 最小投票BZOJ 1934([Shoi2007]Vote 善意的投票-最小割)

    上班之余抽点时间出来写写博文,希望对新接触的朋友有帮助.今天在这里和大家一起学习一下最小投票 1934: [Shoi2007]Vote 好心的投票 Time Limit: 1 Sec Memory L ...

  4. 【BZOJ】1934: [Shoi2007]Vote 善意的投票(网络流/-二分图匹配)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1934 一开始我想到了这是求最小割,但是我认为这题二分图可做,将1的放在左边,0的放在右边,然后朋友连 ...

  5. BZOJ 1934 [Shoi2007]Vote 善意的投票(最小割)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1934 [题目大意] 每个人对于投票都有自己原来的观点:1或者0, 他可以违背自己原来的 ...

  6. ●BZOJ 1934 [Shoi2007]Vote 善意的投票

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1934 题解: 题目有点迷. S向为1的点连边,为0的点向T连边,在有关系的两个点之间连双向边 ...

  7. 【刷题】BZOJ 1934 [Shoi2007]Vote 善意的投票

    Description 幼儿园里有n个小朋友打算通过投票来决定睡不睡午觉.对他们来说,这个问题并不是很重要,于是他们决定发扬谦让精神.虽然每个人都有自己的主见,但是为了照顾一下自己朋友的想法,他们也可 ...

  8. bzoj 1934: [Shoi2007]Vote 善意的投票

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

  9. bzoj 1934: [Shoi2007]Vote 善意的投票 (最小割)

    原来是赞同的连源,原来是反对的连汇,然后是朋友的就连在一起,这样最小割就是割掉违背和谐的吧 type arr=record toward,next,cap:longint; end; const ma ...

随机推荐

  1. PB出现中文乱码

    在design>option>font把字体都设定为宋体 tools>system option>font 把字体都设定为宋体 然后重启PB即可

  2. ef codeFirst 修改表结构 增加字段等 EF code first需要重新生成库导致数据丢失的问题.

    需要在库程序包管理器里依次执行以下命令: 1.启用迁移功能:Enable-Migrations -ContextTypeName MvcMovie.Models.MovieDbContext 2.建立 ...

  3. lua技巧分享之保护执行

    我们在c#/c++里为了防止调用出现异常的时候程序可以正常的执行,经常使用try{}catch{}的结构, 那么,语言简单的lua是怎么做到的呢?答案就在pcall 先简单的介绍一下这个函数: --尝 ...

  4. Struts2基本包作用详解

    asm-3.3.jar作用:操作java字节码的类库包路径及主要类:未提供 asm-commons-3.3.jar作用:提供了基于事件的表现形式包路径及主要类:未提供 asm-tree-3.3.jar ...

  5. JavaScript学习笔记 - 进阶篇(2)- 数组

    什么是数组 我们知道变量用来存储数据,一个变量只能存储一个内容.假设你想存储10个人的姓名或者存储20个人的数学成绩,就需要10个或20个变量来存储,如果需要存储更多数据,那就会变的更麻烦.我们用数组 ...

  6. 20141201--测试 jQuery

    测试 JavaScript 框架库 - jQuery jQuery 是一个 JavaScript 库. 引用 jQuery <!DOCTYPE html> <html> < ...

  7. UI1_ScrollViewHomeWork

    // // AppDelegate.m // UI1_ScrollViewHomeWork // // Created by zhangxueming on 15/7/13. // Copyright ...

  8. ESB数据发布思路

    通过esb已经将数据采集进数据库,现在需要开放一个接口,接受请求参数,进而通过参数进行数据查询,返回一段json格式的数据. ▼流程图: 刚开始尝试了很多个版本,可能是esb开发工具还用不熟练的原因吧 ...

  9. 杭电ACM2057--A + B Again

    这是题目 A + B Again 这是源代码: #include <stdio.h> int main() { __int64 a,b; while (scanf("%I64X ...

  10. Linux I/O模型

    同步阻塞I/O 在此种方式下,用户进程在发起一个I/O操作以后,必须等待I/O操作的完成,只有当真正完成了I/O操作以后,用户进程才能运行.Java传统的I/O模型属于此种方式. 同步非阻塞I/O 在 ...