大意:在一个二维坐标系上有nx个人和ny把伞,每个人都有自己的移动速度,问有多少人可以再 time 时间内移动到不同的雨伞处(不允许两个人共用一把伞)。
 
输入数据:
第一行是一个T代表T组测试数据。
开始是一个数字  time (1 <=time<= 5) 代表还有t时间就开始下雨了。 
接下来是一个数字m代表宾客的数量。
接下来m行每行一个x,y 代表宾客所在的坐标, s代表宾客移动的速度
然后是一个数字n  代表伞的数量。
接下来n行就是伞的坐标。(所有坐标的绝对值是小于10000的)
输出:
在规定时间内最多有多少人可以拿到伞
 
题目解析:
以人和伞建立二分图,如果人能在规定时间内到达 这个伞,那么我们就以人和伞之间建边。
事实上经过验证超时了,那么换种方法,经过百度发现是需要一个Hopcroft-Carp(也有叫Hopcroft-Karp反正也是傻傻分不清楚)
这道题目要是使用vetor建立邻接表也是会超时的 毕竟数据量比较大
 
  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<algorithm>
  4. #include<iostream>
  5. #include<vector>
  6. #include<queue>
  7. #include<cmath>
  8. using namespace std;
  9. #define INF 0x3fffffff
  10. #define maxn 3005
  11. bool vis[maxn];
  12. int Px[maxn], Py[maxn];///Px[i]表示在X集合的i 所匹配Y的值的编号是 P[i]
  13. int dx[maxn], dy[maxn], Head[maxn];///dx记录X集合每个点所在的层, dy同dx
  14. int n, m, depth, k;
  15. struct node
  16. {
  17. int x, y, s;///这个点的坐标集,人移动的速度
  18. }Peo[maxn], Umb[maxn];///分别表示人的坐标点集, 和伞所在位置的点集
  19.  
  20. struct Edge
  21. {
  22. int v, next;
  23. }e[maxn*maxn];
  24.  
  25. void Add(int a,int b)
  26. {
  27. e[k].v = b;
  28. e[k].next = Head[a];
  29. Head[a] = k;
  30. k ++;
  31. }
  32.  
  33. void Init()
  34. {
  35. k = ;
  36. memset(e, , sizeof(e));
  37. memset(Px, -, sizeof(Px));
  38. memset(Py, -, sizeof(Py));
  39. memset(Head, -, sizeof(Head));
  40. }
  41.  
  42. bool BFS()
  43. {
  44. queue<int> Q;
  45. depth = INF;///记录深度
  46.  
  47. memset(dx, -, sizeof(dx));
  48. memset(dy, -, sizeof(dy));
  49.  
  50. for(int i=; i<n; i++)
  51. {
  52. if(Px[i] == -)
  53. {///以x方的点为源点,进行广搜, 并且是没有加入匹配的点
  54. Q.push(i);
  55. dx[i] = ;
  56. }
  57. }
  58.  
  59. while( Q.size() )
  60. {
  61. int u = Q.front();
  62. Q.pop();
  63.  
  64. if(dx[u] > depth)///?????
  65. break;
  66.  
  67. for(int i=Head[u]; i != -; i = e[i].next)
  68. {
  69. int v = e[i].v;
  70. if(dy[v] == -)
  71. {
  72. dy[v] = dx[v] + ;
  73. /**说明这个点是没有加入到匹配内的, 也就是说我们找到了一条增广路
  74. (因为我们的源点是没进入匹配内的点,而源点到达的这个点也是没有进入匹配的点,
  75. 两个未进入匹配的点,相连了肯定是一对匹配,也就是增广路)*/
  76. if(Py[v] == -)
  77. depth = dy[v];
  78. else///否则源点所连接的就是匹配过的点。
  79. {
  80. dx[Py[v]] = dy[v] + ;
  81. Q.push( Py[v] );
  82. }
  83. }
  84. }
  85. }
  86. return depth != INF;
  87. }
  88.  
  89. bool Find(int u)
  90. {
  91. for(int i=Head[u]; i != -; i = e[i].next)
  92. {
  93. int v = e[i].v;
  94. if(!vis[v] && dx[u] == dy[v] - )///由dx[i]到 dy[v] 可以寻得一条增广路
  95. {
  96. vis[v] = true;
  97.  
  98. /**增广路不在这里,因为我们在dy[v]这个深度的时候已经找到增广路了*/
  99. if(Py[v] != - && dy[v] == depth)
  100. continue;
  101.  
  102. if(Py[v] == - || Find(Py[v]))
  103. {
  104. Py[v] = u;
  105. Px[u] = v;
  106. return true;
  107. }
  108. }
  109. }
  110. return false;
  111. }
  112.  
  113. int solve()
  114. {
  115. int ans = ;
  116. while( BFS() )///确定是否存在增广路
  117. {
  118. memset(vis, false, sizeof(vis));
  119. for(int i=; i<n; i++)
  120. {
  121. if(Px[i] == - && Find(i) )
  122. ans ++;
  123. }
  124. }
  125. return ans;
  126. }
  127.  
  128. int main()
  129. {
  130. int T, time, cas = ;///n 人的个数 m伞的个数
  131. scanf("%d", &T);
  132.  
  133. while(T--)
  134. {
  135. scanf("%d %d", &time, &n);
  136. for(int i=; i<n; i++)
  137. scanf("%d %d %d",&Peo[i].x, &Peo[i].y, &Peo[i].s);
  138. scanf("%d", &m);
  139. for(int i=; i<m; i++)
  140. scanf("%d %d", &Umb[i].x, &Umb[i].y);
  141.  
  142. Init();
  143.  
  144. for(int i=; i<n; i++)///构图
  145. {
  146. for(int j=; j<m; j++)
  147. {
  148. 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) );
  149. if(len <= time*Peo[i].s)
  150. Add(i,j);
  151. }
  152. }
  153. int ans = solve();
  154.  
  155. printf("Scenario #%d:\n%d\n\n", cas ++, ans);
  156. }
  157. return ;
  158. }
  159.  
  160. /*
  161. 3
  162. 1 0 1
  163. 1 0 1
  164. 0 1 0
  165. */

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. ORACLE功能GREATEST功能说明具体实例

    1           语法 GREATEST(expr_1, expr_2, ...expr_n) 2           说明 GREATEST(expr_1, expr_2, ...expr_n ...

  2. Qt 学习之路:视图选择 (QItemSelectionModel)

    选择是视图中常用的一个操作.在列表.树或者表格中,通过鼠标点击可以选中某一项,被选中项会变成高亮或者反色.在 Qt 中,选择也是使用了一种模型.在 model/view 架构中,这种选择模型提供了一种 ...

  3. 汉诺塔III 递推题

    题目描述: 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下.由小到大顺序串着由64个圆盘构成的塔.目的是将最左边杆上的盘全部移到右边的杆上,条件是一次只能移动 ...

  4. diy 电脑 重装系统

    1\组装好电脑 2\硬盘的红灯只亮一会,找不到 硬盘 .bios里 硬盘设置里 IDE修改为 ACHI即可. 3\老毛桃 \ 用桌面的那个分区软件 分区 100G,300G 4\找到U盘 的iso 文 ...

  5. iOS---多线程实现方案一 (pthread、NSThread)

    在iOS开发中,多线程是我们在开发中经常使用的一门技术.那么本文章将和大家探讨一下针对于多线程的技术实现.本文主要分为如下几个部分: iOS开发中实现多线程的方式 单线程 pthread NSThre ...

  6. HDU 2476 String painter(区间dp)

    题意: 给定两个字符串,让求最少的变化次数从第一个串变到第二个串 思路: 区间dp, 直接考虑两个串的话太困难,就只考虑第二个串,求从空白串变到第二个串的最小次数,dp[i][j] 表示i->j ...

  7. 不用jquery等框架实现ajax无刷新登录

    <script type="text/javascript"> window.onload = function () { document.getElementByI ...

  8. css渐变色

    <!DOCTYPE html><html><head> <meta http-equiv="content-type" content=& ...

  9. (转)php中__autoload()方法详解

    转之--http://www.php100.com/html/php/lei/2013/0905/5267.html PHP在魔术函数__autoload()方法出现以前,如果你要在一个程序文件中实例 ...

  10. .net判断用户使用的是移动设备还是PC

    using System.Text.RegularExpressions;//头部引入正则的命名空间 //为了加强准确性,防止支持wap的浏览器如opera,加入操作系统验证.openwave|后为p ...