大意:在一个二维坐标系上有nx个人和ny把伞,每个人都有自己的移动速度,问有多少人可以再 time 时间内移动到不同的雨伞处(不允许两个人共用一把伞)。
 
输入数据:
第一行是一个T代表T组测试数据。
开始是一个数字  time (1 <=time<= 5) 代表还有t时间就开始下雨了。 
接下来是一个数字m代表宾客的数量。
接下来m行每行一个x,y 代表宾客所在的坐标, s代表宾客移动的速度
然后是一个数字n  代表伞的数量。
接下来n行就是伞的坐标。(所有坐标的绝对值是小于10000的)
输出:
在规定时间内最多有多少人可以拿到伞
 
题目解析:
以人和伞建立二分图,如果人能在规定时间内到达 这个伞,那么我们就以人和伞之间建边。
事实上经过验证超时了,那么换种方法,经过百度发现是需要一个Hopcroft-Carp(也有叫Hopcroft-Karp反正也是傻傻分不清楚)
这道题目要是使用vetor建立邻接表也是会超时的 毕竟数据量比较大
 
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<vector>
#include<queue>
#include<cmath>
using namespace std;
#define INF 0x3fffffff
#define maxn 3005
bool vis[maxn];
int Px[maxn], Py[maxn];///Px[i]表示在X集合的i 所匹配Y的值的编号是 P[i]
int dx[maxn], dy[maxn], Head[maxn];///dx记录X集合每个点所在的层, dy同dx
int n, m, depth, k;
struct node
{
int x, y, s;///这个点的坐标集,人移动的速度
}Peo[maxn], Umb[maxn];///分别表示人的坐标点集, 和伞所在位置的点集 struct Edge
{
int v, next;
}e[maxn*maxn]; void Add(int a,int b)
{
e[k].v = b;
e[k].next = Head[a];
Head[a] = k;
k ++;
} void Init()
{
k = ;
memset(e, , sizeof(e));
memset(Px, -, sizeof(Px));
memset(Py, -, sizeof(Py));
memset(Head, -, sizeof(Head));
} bool BFS()
{
queue<int> Q;
depth = INF;///记录深度 memset(dx, -, sizeof(dx));
memset(dy, -, sizeof(dy)); for(int i=; i<n; i++)
{
if(Px[i] == -)
{///以x方的点为源点,进行广搜, 并且是没有加入匹配的点
Q.push(i);
dx[i] = ;
}
} while( Q.size() )
{
int u = Q.front();
Q.pop(); if(dx[u] > depth)///?????
break; for(int i=Head[u]; i != -; i = e[i].next)
{
int v = e[i].v;
if(dy[v] == -)
{
dy[v] = dx[v] + ;
/**说明这个点是没有加入到匹配内的, 也就是说我们找到了一条增广路
(因为我们的源点是没进入匹配内的点,而源点到达的这个点也是没有进入匹配的点,
两个未进入匹配的点,相连了肯定是一对匹配,也就是增广路)*/
if(Py[v] == -)
depth = dy[v];
else///否则源点所连接的就是匹配过的点。
{
dx[Py[v]] = dy[v] + ;
Q.push( Py[v] );
}
}
}
}
return depth != INF;
} bool Find(int u)
{
for(int i=Head[u]; i != -; i = e[i].next)
{
int v = e[i].v;
if(!vis[v] && dx[u] == dy[v] - )///由dx[i]到 dy[v] 可以寻得一条增广路
{
vis[v] = true; /**增广路不在这里,因为我们在dy[v]这个深度的时候已经找到增广路了*/
if(Py[v] != - && dy[v] == depth)
continue; if(Py[v] == - || Find(Py[v]))
{
Py[v] = u;
Px[u] = v;
return true;
}
}
}
return false;
} int solve()
{
int ans = ;
while( BFS() )///确定是否存在增广路
{
memset(vis, false, sizeof(vis));
for(int i=; i<n; i++)
{
if(Px[i] == - && Find(i) )
ans ++;
}
}
return ans;
} int main()
{
int T, time, cas = ;///n 人的个数 m伞的个数
scanf("%d", &T); while(T--)
{
scanf("%d %d", &time, &n);
for(int i=; i<n; i++)
scanf("%d %d %d",&Peo[i].x, &Peo[i].y, &Peo[i].s);
scanf("%d", &m);
for(int i=; i<m; i++)
scanf("%d %d", &Umb[i].x, &Umb[i].y); Init(); for(int i=; i<n; i++)///构图
{
for(int j=; j<m; j++)
{
double len = sqrt( 1.0*(Peo[i].x-Umb[j].x)*(Peo[i].x-Umb[j].x) + (Peo[i].y-Umb[j].y)*(Peo[i].y-Umb[j].y) );
if(len <= time*Peo[i].s)
Add(i,j);
}
}
int ans = solve(); printf("Scenario #%d:\n%d\n\n", cas ++, ans);
}
return ;
} /*
3
1 0 1
1 0 1
0 1 0
*/

HDU 2389 Rain on your Parade的更多相关文章

  1. HDU 2389 Rain on your Parade / HUST 1164 4 Rain on your Parade(二分图的最大匹配)

    HDU 2389 Rain on your Parade / HUST 1164 4 Rain on your Parade(二分图的最大匹配) Description You're giving a ...

  2. HDU 2389 ——Rain on your Parade——————【Hopcroft-Karp求最大匹配、sqrt(n)*e复杂度】

    Rain on your Parade Time Limit:3000MS     Memory Limit:165535KB     64bit IO Format:%I64d & %I64 ...

  3. HDU 2389 Rain on your Parade(二分匹配,Hopcroft-Carp算法)

    Rain on your Parade Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 655350/165535 K (Java/Ot ...

  4. HDU 2389 Rain on your Parade 最大匹配(模板题)【HK算法】

    <题目链接> 题目大意:有m个宾客,n把雨伞,预计时间t后将会下大雨,告诉你每个宾客的位置和速度,每把雨伞的位置,问你最多几个宾客能够拿到伞. 解题分析: 本题就是要我们求人与伞之间的最大 ...

  5. Hdu 3289 Rain on your Parade (二分图匹配 Hopcroft-Karp)

    题目链接: Hdu 3289 Rain on your Parade 题目描述: 有n个客人,m把雨伞,在t秒之后将会下雨,给出每个客人的坐标和每秒行走的距离,以及雨伞的位置,问t秒后最多有几个客人可 ...

  6. HDOJ 2389 Rain on your Parade

     HK.... Rain on your Parade Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 655350/165535 K ...

  7. 【HDOJ】2389 Rain on your Parade

    读题显然是二分图匹配,看成guest与umbrella的匹配.匈牙利果断TLE了,其实时间卡的相当紧.HK过的,750ms. /* 2389 */ #include <iostream> ...

  8. Rain on your Parade

    Rain on your Parade Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 655350/165535 K (Java/Ot ...

  9. Hdu2389 Rain on your Parade (HK二分图最大匹配)

    Rain on your Parade Problem Description You’re giving a party in the garden of your villa by the sea ...

随机推荐

  1. PHP 計算字符串長度函數

    PHP內置的字符串長度函數strlen無法正確處理中文字符串,它得到的只是字符串所占的字節數.對於GB2312的中文編碼,strlen得到的值是漢字個數的2倍,而對於UTF-8編碼的中文,就是3倍的差 ...

  2. 第一篇:数据工程师眼中的智能电网(Smart Grid)

    前言 想必第一次接触到智能电网这个概念的人,尤其是互联网从业者,都会顾名思义的将之理解为"智能的电网". 然而智能电网中的"智能"是广义上的智能,它就是指更好的 ...

  3. [转] tomcat结合nginx使用小结

    相信很多人都听过nginx,这个小巧的东西慢慢地在吞食apache和IIS的份额.那究竟它有什么作用呢?可能很多人未必了解. 说到反向代理,可能很多人都听说,但具体什么是反向代理,很多人估计就不清楚了 ...

  4. SpringMVC中文乱码

    刚刚构建的SpringMVC项目,一般都是中文乱码的. 这时的工程就是一个JSP页面的事情,可以添加如下代码 <%@ page language="java" import= ...

  5. 化繁为简,无需后端。巧用Yql+rss,搭建我的个人网站

    [本文含有大量的心理描写,没耐心的看官直接跳转到末尾即可] 前言: 最近做好了个人网站.很多人都喜欢用WordPress弄一个自己的博客之类的,但其实我觉得没这个必要,Lofter的功能.界面神马的于 ...

  6. AWS S3国内与国外的区别

    S3云存储国际版目前正被某墙,国内部分地区只能下载不能上传,所以建议S3使用国内AWS的. 国内S3与国外S3在编程时注意以下几点: 1)URL不通用 国际版的S3可以使用不带Region的URL,例 ...

  7. codevs 4909 寂寞的堆(写的好丑0.0)

    #include<iostream> #include<cstdio> #include<cstring> #include<cmath> #defin ...

  8. ecshop首页调用指定商品分类下的商品品牌列表

    转之--http://www.16css.com/ecshop/735.html 通过二次开发可以实现ECSHOP首页调用指定分类下的品牌列表. 第一步: 打开根目录下的index.php 在最后面 ...

  9. 加入强调语气,使用<strong>和<em>标签

    有了段落又有了标题,现在如果想在一段话中特别强调某几个文字,这时候就可以用到<em>或<strong>标签. 但两者在强调的语气上有区别:<em> 表示强调,< ...

  10. CSS 布局Float 【3】

    float 属性定义元素在哪个方向浮动. 浮动元素会生成一个块级框,而不论它本身是何种元素. 如果浮动非替换元素,则要指定一个明确的宽度:否则,它们会尽可能地窄. 注释:假如在一行之上只有极少的空间可 ...