#include <cstdio>
 #include <cstring>
 #include <algorithm>

 const int inf=0x3f3f3f3f;
 ;

 struct Edge
 {
     int to;
     int next;
     int capacity;

     void assign(int t,int n,int c)
     {
         to=t; next=n; capacity=c;
     }
 };

 Edge edgeList[];
 ];
 ;

 inline void init()
 {
     edgeCnt=;
     memset(head,-,sizeof(head));
 }

 ];
 int X;

 inline int idx(char s)
 {
     switch(s)
     {
     ;
     ;
     ;
     ;
     ;
     ;
     }
 }

 inline void addEdge(int v1,int v2,int c)
 {
     edgeList[edgeCnt].assign(v2,head[v1],c);
     head[v1]=edgeCnt++;
     edgeList[edgeCnt].assign(v1,head[v2],);
     head[v2]=edgeCnt++;
 }

 bool input()
 {
     scanf("%s",cmd);
     ]=='E') return false;

     scanf("%d",&X);
     ;i<=X+;i++)
     {
         scanf("%s",cmd);
         ]);
         ]);
         for(int j=sm;j<=lg;j++) addEdge(j,i,inf);
         addEdge(i,sink,);
     }
     ;i<=;i++)
     {
         int n; scanf("%d",&n);
         addEdge(,i,n);
     }
     scanf("%s",cmd);
     return true;
 }

 ];

 #include <queue>

 int bfs()
 {
     memset(dist,,sizeof(dist));
     dist[]=;

     std::queue<int> __bfs;
     __bfs.push();

     while(!__bfs.empty())
     {
         int cur=__bfs.front();
         __bfs.pop();

         ;e=edgeList[e].next)
         {
             int __to=edgeList[e].to;
             if(edgeList[e].capacity && !dist[__to])
             {
                 dist[__to]=dist[cur]+;
                 __bfs.push(__to);
             }
         }
     }
     return dist[sink];
 }

 int dinic_aux(int cur,int flow)
 {
     if(cur==sink) return flow;

     ;
     ;
     ;e=edgeList[e].next)
     {
         int __to=edgeList[e].to;
          && edgeList[e].capacity)
         {
             temp=dinic_aux(__to,std::min(flow,edgeList[e].capacity));
             res+=temp;
             flow-=temp;
             edgeList[e].capacity-=temp;
             edgeList[e^].capacity+=temp;
         }
     }
     return res;
 }

 inline int dinic()
 {
     ;
     ,inf);
     return res;
 }

 const char success[]="T-shirts rock!";
 const char fail[]="I'd rather not wear a shirt anyway...";

 inline void solve()
 {
     bool proc=true;
     while(proc)
     {
         init();
         proc=input();
         if(proc) printf("%s\n",dinic()==X?success:fail);
     }
 }

 ; }

Using Dinic Algorithm

这道题有两种解决思路:

(1)拆点。将n件同样尺码的T恤拆成n个节点,然后对于每一个分离的节点向对应的人连边

  效率比较低,点的个数最大有可能达到100以上

(2)网络流。建模的基本思想与一般二分图匹配的网络流建模相同,只是从源点向T恤尺码代表的节点连边时,载量设为该种T恤的件数

  点的个数不超过30,相对比较高效

Appendix:二分图匹配的网络流建模:

约定二分图的两部分记作A和B

设立一个源点和汇点。源点同A中所有点连边,载量设为1(表示该点只能在匹配中被选中一次);汇点同B中所有点连边,载量也设为1

二分图中原来的边保留,令其方向为A→B,载量为任意正整数

对于网络流问题,边表是个很不错的选择。既能像邻接表那样节约空间,又能方便地记录反向边。

记正向边的标号为2x,那么反向边的标号就是2x+1,访问反向边只需将正向边的标号xor 1

POJ2584 T-Shirt Gumbo 二分图匹配(网络流)的更多相关文章

  1. LOJ 2548 「JSOI2018」绝地反击 ——二分图匹配+网络流手动退流

    题目:https://loj.ac/problem/2548 如果知道正多边形的顶点,就是二分答案.二分图匹配.于是写了个暴力枚举多边形顶点的,还很愚蠢地把第一个顶点枚举到 2*pi ,其实只要 \( ...

  2. cogs_396_魔术球问题_(最小路径覆盖+二分图匹配,网络流24题#4)

    描述 http://cojs.tk/cogs/problem/problem.php?pid=396 连续从1开始编号的球,按照顺寻一个个放在n个柱子上,\(i\)放在\(j\)上面的必要条件是\(i ...

  3. P3386 【模板】二分图匹配 -网络流版

    二分图匹配 题目背景 二分图 感谢@一扶苏一 提供的hack数据 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+ ...

  4. POJ-3041-建图/二分图匹配/网络流

    Asteroids Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 26351   Accepted: 14254 Descr ...

  5. BZOJ 1191: [HNOI2006]超级英雄Hero(二分图匹配)

    云神说他二分图匹配从来都是用网络流水过去的...我要发扬他的精神.. 这道题明显是二分图匹配.网络流的话可以二分答案+最大流.虽然跑得很慢.... -------------------------- ...

  6. 【wikioi】1922 骑士共存问题(网络流/二分图匹配)

    用匈牙利tle啊喂?和网络流不都是n^3的吗(匈牙利O(nm), isap O(n^2m) 但是isap实际复杂度很优的(二分图匹配中,dinic是O(sqrt(V)*E),不知道isap是不是一样. ...

  7. cogs_14_搭配飞行员_(二分图匹配+最大流,网络流24题#01)

    描述 http://cojs.tk/cogs/problem/problem.php?pid=14 有一些正飞行员和副飞行员,给出每个正飞行员可以和哪些副飞行员一起飞.一架飞机上必须一正一副,求最多多 ...

  8. 【BZOJ4554】游戏(二分图匹配,网络流)

    [BZOJ4554]游戏(二分图匹配,网络流) 题解 Description 在2016年,佳缘姐姐喜欢上了一款游戏,叫做泡泡堂.简单的说,这个游戏就是在一张地图上放上若干个炸弹,看 是否能炸到对手, ...

  9. 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...

随机推荐

  1. cheerio返回数据格式

    通读cheerio API { options: { decodeEntities: false, withDomLvl1: true, normalizeWhitespace: false, xml ...

  2. C#调用Web Service时的身份验证

    原理:webservice所在的系统中,在系统域中建立用于登录的软件的用户和密码,软件登录时将用户名.密码和登录的本机的域的名字通过webService的NetworkCredential传递到web ...

  3. HDOU/HDU 2548 两军交锋(看你的思维~)

    Problem Description 话说辽军与MCA相峙多年,终于在一个秋日的早晨爆发了一次大规模的冲突.情况是这样子的,当天上午,由耶律-Pacision领军的辽军忽然带领数万人马浩浩荡荡向MC ...

  4. JavaScript高级程序设计15.pdf

    组合继承的问题是会调用2次超类型构造函数 寄生组合式继承 即通过借用构造函数来继承属性,通过原型链的形式来继承方法,思路:不必为了指定子类型的原型而调用超类型的原型,我们所需要的无非是超类型原型的一个 ...

  5. lvs,haproxy,keepalived,heartbeat

    lvs的是通过vrrp协议进行数据包转发的,提供的是4层的负载均衡.特点是效率高,只要你机器网卡抗的住就不是问题. haproxy可以提供4层或7层的数据转发服务,能做到7层的好处是可以根据服务所处的 ...

  6. OpenSource

    SugarCRM 客户关系管理系统(CRM).SugarCRM开源版是一款完全开放源代码的商业开源软件 OPENFILER 基于浏览器的免费网络存储管理实用程序,可以在单一框架中提供基于文件的网络连接 ...

  7. Django-RQ首页、文档和下载 - Django 和 RQ 集成 - 开源中国社区

    Django-RQ首页.文档和下载 - Django 和 RQ 集成 - 开源中国社区 Django-RQ 项目实现了 Django 框架和 RQ 消息队列之间的集成.

  8. myisam MySQL 锁问题

    2016-07-23  (点击上方公众号,可快速关注) 来源:阿里云 RDS - 数据库内核组 链接:http://mysql.taobao.org/monthly/2016/03/10/ 前言 最近 ...

  9. Codeforces Round #387(div 2)

    A =w= B VOV C QoQ D 题意:贝尔兰冬天很冷,那么司机要换上冬天专用轮胎才能开车.假设冬天一共有n天,有一套冬天专用轮胎,仅能使用k天,这套轮胎不管什么温度都能用,而夏天用的轮胎只能在 ...

  10. linux系统启动oracle

    linux下启动oracle需要两步:一.启动监听  二.启动服务 一.启动监听 监听命令:lsnrctl ,具体使用方法如下 1.lsnrctl status:检查当前监听器的状态 2.lsnrct ...