题意:

我是歌手

Time Limit: 6000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)

Total Submission(s): 287 Accepted Submission(s): 97

Problem Description
2013年一开始,一档音乐节目“我是歌手”就惊艳了大家一回。闲话少说,现在,你成为了这档节目的总导演,你的任务很简单,安排每一期节目的内容。

现在有N个歌手,M种歌曲流派(Rock,Pop之类),每个歌手都有自己擅长的流派领域,这些资料都已整理好。你的工作是,安排尽可能多场的演唱比赛。每一场比赛所有歌手都必须上场,为了提高收视率,每个人演唱的歌曲类型不能相同,即便一些歌手要被迫选择一些他们不擅长的。同时,为了展现全面性,在不同的演唱比赛上,每个歌手都会安排不同的歌曲流派。

但是问题是,对于任何一个歌曲流派的歌迷,如果超过K个不擅长的歌手演唱了这种歌曲,他们就会表示不满,比如,发一些宣泄不满的帖子微博,为了表示观点挑起事端等等。你当然不希望这些事情与你的节目有关,在这个前提下,你可以任意安排尽可能多的比赛场次。


Input
输入第一行为T,表示有T组测试数据。

每组数据以四个数字N,M,L, K开始。L表示有L组擅长关系,接下来的L行,每一行有两个数字Ai,Bi,表示歌手Ai擅长Bi类型的歌曲。

[Technical Specification]

1. 1 <= T <= 100

2. 1 <= N <= M <= 74, 0 <= K <= N

3. 0 <= L <= N*M

4. 1 <= Ai <= N, 1 <= Bi <= M, 相同关系不会重复出现


Output
对每组数据,先输出为第几组数据,然后输出最多比赛场次。


Sample Input

3
1 1 1 0
1 1
1 3 0 1
3 3 5 1
1 1
1 2
2 2
2 3
3 1


Sample Output

Case 1: 1
Case 2: 3
Case 3: 2

Hint


对第三组样例,可以如此安排:
第一场三位歌手分别演唱(2,3,1)类型的歌曲,第二场分别演唱(1,2,3)。
这样只有类型3被不擅长的歌手演唱过1次,挑剔的歌迷观众还可以接受。



思路:
      没话说,看完第一反应就是个二分最大流,关键是在建图,说下建图吧.自己弱渣,建图建了4种才ac...
      
      设立超级远点和终点 s,t.
      s连接每一个人,流量是当前二分的 mid.
      然后连接 数据中给的人和歌曲类型,流量为1.
      每种类型连接t流量是mid.
      然后把每个歌曲类型k在拆出来一个点k'
      枚举每个人,如果当前这个人没连接k ,那么连接k'流量1
      每个k'连接k,流量是输入的那个K
    
      然后跑最大流,如果 ans >= mid * N,那么mid = low + 1.............

#include<stdio.h>
#include<string.h>
#include<queue> #define N_node 1000
#define N_edge 1000000
#define INF 1000000000

using namespace
std; typedef struct
{
int
to ,cost ,next;
}
STAR; typedef struct
{
int
x ,t;
}
DEP; typedef struct
{
int
a ,b;
}
EDGE; STAR E[N_edge];
EDGE edge[N_edge];
DEP xin ,tou;
int
list[N_node] ,tot;
int
list2[N_node];
int
deep[N_node];
int
mark[N_node][N_node]; void add(int a ,int b ,int c)
{

E[++tot].to = b;
E[tot].cost = c;
E[tot].next = list[a];
list[a] = tot; E[++tot].to = a;
E[tot].cost = 0;
E[tot].next = list[b];
list[b] = tot;
} int
minn(int x, int y)
{
return
x < y ? x : y;
} bool
bfs_deep(int s ,int t ,int n)
{

queue<DEP>q;
xin.x = s;
xin.t = 0;
memset(deep ,255 ,sizeof(deep));
deep[s] = 0;
q.push(xin);
while(!
q.empty())
{

tou = q.front();
q.pop();
for(int
k = list[tou.x] ;k ;k = E[k].next)
{

xin.x = E[k].to;
xin.t = tou.t + 1;
if(
deep[xin.x] != -1 || !E[k].cost)
continue;

deep[xin.x] = xin.t;
q.push(xin);
}
}
for(int
i = 0; i <= n ;i ++)
list2[i] = list[i];
return
deep[t] != -1;
} int
dfs_flow(int s ,int t ,int flow)
{
if(
s == t) return flow;
int
nowflow = 0;
for(int
k = list2[s] ;k ;k = E[k].next)
{
int
to = E[k].to;
int
c = E[k].cost;
list2[s] = k;
if(
deep[to] != deep[s] + 1 || !E[k].cost)
continue;
int
tmp = dfs_flow(to ,t ,minn(c ,flow - nowflow));
nowflow += tmp;
E[k].cost -= tmp;
E[k^1].cost += tmp;
if(
nowflow == flow) break;
}
if(!
nowflow) deep[s] = 0;
return
nowflow;
} int
DINIC(int s ,int t ,int n)
{
int
ans = 0;
while(
bfs_deep(s ,t ,n))
{

ans += dfs_flow(s ,t ,INF);
}
return
ans;
} bool
ok(int mid ,int L ,int K ,int N ,int M)
{

memset(list ,0 ,sizeof(list));
tot = 1;
int
s = 0 ,t = N + M + M + 1 ,i;
for(
i = 1 ;i <= N ;i ++)
add(s ,i ,mid);
for(
i = 1 ;i <= M ;i ++)
{

add(i + N ,t ,mid);
add(i + N + M ,i + N ,K);
} for(
i = 1 ;i <= L ;i ++)
add(edge[i].a ,edge[i].b + N,1); for(i = 1 ;i <= N ;i ++)
for(int
j = 1 ;j <= M ;j ++)
if(!
mark[i][j])
add(i ,j + N + M ,1); return DINIC(s ,t ,t) >= mid * N;
} int main ()
{
int
N ,M ,L ,K;
int
i ,j ,a ,b;
int
low ,mid ,up;
int
t ,cas = 1;
scanf("%d" ,&t);
while(
t--)
{

scanf("%d %d %d %d" ,&N ,&M ,&L ,&K);
memset(mark ,0 ,sizeof(mark));
for(
i = 1 ;i <= L ;i ++)
{

scanf("%d %d" ,&edge[i].a ,&edge[i].b);
mark[edge[i].a][edge[i].b] = 1;
}

low = 0 ,up = M;
int
ans = 0;
while(
low <= up)
{

mid = (low + up) >> 1;
if(
ok(mid ,L ,K ,N ,M))
{

ans = mid;
low = mid + 1;
}
else

up = mid - 1;
}

printf("Case %d: %d\n" ,cas ++ ,ans);
}
return
0;
}


hdu4560 不错的建图,二分最大流的更多相关文章

  1. 网络流--最大流--POJ 2139(超级源汇+拆点建图+二分+Floyd)

    Description FJ's cows really hate getting wet so much that the mere thought of getting caught in the ...

  2. zoj 3460 Missile【经典建图&&二分】

    Missile Time Limit: 2 Seconds      Memory Limit: 65536 KB You control N missile launching towers. Ev ...

  3. 【ARC069F】Flags 2-sat+线段树优化建图+二分

    Description ​ 数轴上有 n 个旗子,第 ii 个可以插在坐标 xi或者 yi,最大化两两旗子之间的最小距离. Input ​ 第一行一个整数 N. ​ 接下来 N 行每行两个整数 xi, ...

  4. POJ 1149 PIGS 建图,最大流

    题意: 你m个猪圈以及每个猪圈里原来有多少头猪,先后给你n个人,每个人能打开某一些猪圈并且他们最多想买Ki头猪,在每一个人买完后能将打开的猪圈中的猪顺意分配在这次打开猪圈里,在下一个人来之前 已打开的 ...

  5. HDU 4292 Food (建图思维 + 最大流)

    (点击此处查看原题) 题目分析 题意:某个餐馆出售f种食物,d种饮料,其中,第i种食物有fi份,第i种饮料有di份:此时有n个人来餐馆吃饭,这n个人必须有一份食物和一份饮料才会留下来吃饭,否则,他将离 ...

  6. Leapin' Lizards(经典建图,最大流)

    Leapin' Lizards http://acm.hdu.edu.cn/showproblem.php?pid=2732 Time Limit: 2000/1000 MS (Java/Others ...

  7. POJ - 1149 PIGS (建图思维+最大流)

    (点击查看原题) 题目分析 (以下均为 Edelweiss 大佬的思路,博主承认自己写不了这么好,但是学习的心促使我记录下这个好题的写法,所以代码是我写的) [题目大意] 有 M 个猪圈,每个猪圈里初 ...

  8. poj 2226 Muddy Fields(合理建图+二分匹配)

    /* 题意:用木板盖住泥泞的地方,不能盖住草.木板任意长!可以重叠覆盖! '*'表示泥泞的地方,'.'表示草! 思路: 首先让我们回忆一下HDU 2119 Matrix这一道题,一个矩阵中只有0, 1 ...

  9. 牛客练习赛53 D 德育分博弈政治课 (思维建图,最大流)

    牛客练习赛53 D德育分博弈政治课 链接:https://ac.nowcoder.com/acm/contest/1114/D来源:牛客网 题目描述 德育分学长最近玩起了骰子.他玩的骰子不同,他的骰子 ...

随机推荐

  1. 区分函数防抖&函数节流

    1. 概念区分 函数防抖:触发事件后,在n秒内函数只能执行一次,如果触发事件后在n秒内又触发了事件,则会重新计算函数延执行时间. 简单说: 频繁触发, 但只在特定的时间内才执行一次代码,如果特定时间内 ...

  2. POJ-2195(最小费用最大流+MCMF算法)

    Going Home POJ-2195 这题使用的是最小费用流的模板. 建模的时候我的方法出现错误,导致出现WA,根据网上的建图方法没错. 这里的建图方法是每次到相邻点的最大容量为INF,而花费为1, ...

  3. pytorch(07)数据模型的读取

    DataLoader与Dataset pytorch中的数据读取机制 graph TB DataLoader --> DataLoaderIter DataLoaderIter --> S ...

  4. Python Flask框架路由简单实现

    Python Flask框架路由的简单实现 也许你听说过Flask框架.也许你也使用过,也使用的非常好.但是当你在浏览器上输入一串路由地址,跳转至你所写的页面,在Flask中是怎样实现的,你是否感到好 ...

  5. 测试平台系列(1) 搭建Flask服务

    搭建Flask服务 项目地址 点我进入项目地址 代码都会在这里有所展示,喜欢的话可以帮点个star,谢谢大家了!如果你喜欢该教程,也可以分享给其他人. 关于选型 想了很久,本来打算用「Gin」做为后端 ...

  6. C# 应用 - 使用 HttpWebRequest 发起 Http 请求

    helper 类封装 调用 1. 引用的库类 \Reference Assemblies\Microsoft\Framework\.NETFramework\v4.6\System.dll Syste ...

  7. 001-HashMap源码分析

    HashMap源码分析 哈希表(hash table)也叫散列表,是一种非常重要的数据结构,应用场景及其丰富,许多缓存技术(比如 memcached)的核心其实就是在内存中维护一张大的哈希表. 一.什 ...

  8. [unknown source] 整数拆分

    一.题目 题目描述 定义一个整数拆分序列 \(a\) 的权值为: \[\sum_{i=1}^n\sum_{j=1}^{i-1}\gcd(a_i,a_j) \] 求对于一个整数 \(n\) 所有整数拆分 ...

  9. 关于HDFS存储元数据的NameNode持久化存储

    NameNode持久化场景引入: 问题:NameNode宕机,导致内存中的文件元数据丢失怎么办?我们知道元数据是存储来内存中的,所以一旦宕机,内存数据是会丢失的,因此为了避免数据丢失,HDFS中出现了 ...

  10. golang io操作之写篇

    /** * @author livalon * @data 2018/9/4 15:11 */ package main import ( "os" "fmt" ...