HDU 2389 Rain on your Parade
#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的更多相关文章
- 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 ...
- 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 ...
- 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 ...
- HDU 2389 Rain on your Parade 最大匹配(模板题)【HK算法】
<题目链接> 题目大意:有m个宾客,n把雨伞,预计时间t后将会下大雨,告诉你每个宾客的位置和速度,每把雨伞的位置,问你最多几个宾客能够拿到伞. 解题分析: 本题就是要我们求人与伞之间的最大 ...
- Hdu 3289 Rain on your Parade (二分图匹配 Hopcroft-Karp)
题目链接: Hdu 3289 Rain on your Parade 题目描述: 有n个客人,m把雨伞,在t秒之后将会下雨,给出每个客人的坐标和每秒行走的距离,以及雨伞的位置,问t秒后最多有几个客人可 ...
- HDOJ 2389 Rain on your Parade
HK.... Rain on your Parade Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 655350/165535 K ...
- 【HDOJ】2389 Rain on your Parade
读题显然是二分图匹配,看成guest与umbrella的匹配.匈牙利果断TLE了,其实时间卡的相当紧.HK过的,750ms. /* 2389 */ #include <iostream> ...
- Rain on your Parade
Rain on your Parade Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 655350/165535 K (Java/Ot ...
- 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 ...
随机推荐
- 怎样使用 iOS 7 的 AVSpeechSynthesizer 制作有声书(2)
切分语句 软件project的一条定律是数据和代码分离.这样做会使代码更易于測试,即使输入的数据发生改变,你的代码也能够同意.甚至于,程序能在执行中实时下载新的数据.假设程序能在执行中下载新书岂不是更 ...
- hdu3722Card Game(KM最大带权匹配)
题目请戳这里 题目大意:给n个字符串,再给一个n的排列:p1,p2....pn.然后将第i个字符串贴到第pi个字符串后面,然后形成一个环.pi的首字符和第i个字符串的末尾字符就相邻,如果这2个字符相等 ...
- RSA体系 c++/java相互进行加签验签--转
在web开发中,采用RSA公钥密钥体系自制ukey,文件证书登陆时,普遍的做法为:在浏览器端采用c++ activex控件,使用 c++的第三库openssl进行RAS加签操作,在服务器端采用java ...
- Android实现网络多线程断点续传下载(转)
本示例介绍在Android平台下通过HTTP协议实现断点续传下载. 我们编写的是Andorid的HTTP协议多线程断点下载应用程序.直接使用单线程下载HTTP文件对我们来说是一件非常简单的事.那么,多 ...
- Java基础知识强化17:JAVA不可以将所覆盖的方法的访问权限变得比父类的小
首先我们看一下下面的代码如下: interface I { void go(); } abstract class A implements I { } class C extends A { voi ...
- jquery获取元素到屏幕底的可视距离
jquery获取元素到屏幕底的可视距离 要打对号的图里的height(我自称为可视高度:滚动条未滑到最底端) 不是打叉图里的到页面底部(滚动条到最底部时的height)(offset().top方法 ...
- 免写前缀JS包--prefixfree.min.js--插件
/** * StyleFix 1.0.3 & PrefixFree 1.0.7 * @author Lea Verou * MIT license */ (function(){functio ...
- C++简单工厂模式
核心思想:用一个工厂类根据不同的输入条件new出不同的派生类指针,然后由多态调用不同派生类中virtual函数,得到不同的结果 所有的判断处理在工厂类中完成,通过CreateFactory函数,根据不 ...
- android 9Path图片的使用
Android UI设计时,经常会使用图片作为背景,比如给按钮设置背景图片时,图片会默认缩放来适应整个按钮.但是有时这种缩放效果并不是我们所需求的.而我们只是希望缩放图片的特定位置,以此来保证按钮的视 ...
- 完数c实现
完数,顾名思义,就是一个数如果恰好等于它的因子之和.例如6=1+2+3.编写找出1000以内的所有完数 #include <stdio.h> #include <stdlib.h&g ...