题目好长好难懂0 0,直接翻了翻网上的题解。
大意是这样的:有n(2≤n≤300)n(2 \leq n\leq 300)个点,每个点有个频率f(400.0≤f≤789.0)f(400.0 \leq f \leq 789.0)和坐标还有半径。如果点i能走到点j,那么以两个点为圆心半径分别为Ri,RjR_i,R_j的圆相交,即(Xi−Xj)2+(Yi−Yj)2−−−−−−−−−−−−−−−−−−−√<Ri+Rj\sqrt{(X_i-X_j)^2+(Y_i-Y_j)^2} ,且需要fi<fjf_i。问是否存在两条以上从起点走到终点的路径(起点的f值为400.0,终点为789.0),除起点终点以外每个点只能经过一次。
别看题意那么复杂,题却不难。因为每个点只能走一遍,因此要拆点,容量为1。然后,直接O(N2)O(N^2)连边吧,之后跑网络流。

#include<cstdio>
#include<vector>
#include<cstring>
#include<algorithm>
#define MAXN 1010
using namespace std;
inline int Min(int a,int b)
{return a<b?a:b;}
struct E
{int v,w,op;E(){}E(int a,int b,int c){v = a; w = b; op = c;}
};
vector<E> g[MAXN];
int d[MAXN],vd[MAXN],n,s,t,flow;
struct Node
{double f;int x,y,r;bool operator <(const Node &b)const{return f < b.f;}
}a[MAXN];
bool inarea(int i,int j)
{return (a[i].x-a[j].x)*(a[i].x-a[j].x)+(a[i].y-a[j].y)*(a[i].y-a[j].y) < (a[i].r+a[j].r)*(a[i].r+a[j].r);
}
int aug(int i,int augco)
{int j,augc = augco,mind = t-1,delta,sz = g[i].size();if(i == t) return augco;for(j = 0; j < sz; j++){int v = g[i][j].v;if(g[i][j].w){if(d[i] == d[v]+1){delta = Min(augc,g[i][j].w);delta = aug(v,delta);g[i][j].w -= delta;g[v][g[i][j].op].w += delta;augc -= delta;if(d[s] >= t) return augco - augc;if(augc == 0) break;}if(d[v] < mind) mind = d[v];}}if(augc == augco){vd[d[i]]--;if(vd[d[i]] == 0) d[s] = t;d[i] = mind+1;vd[d[i]]++;}return augco - augc;
}
void sap()
{flow = 0;memset(d,0,sizeof d);memset(vd,0,sizeof vd);vd[0] = t;while(d[s] < t)flow += aug(s,0x3f3f3f3f);
}
int main()
{int T;scanf("%d",&T);while(T--){memset(a,0,sizeof a);scanf("%d",&n);for(int i = 1; i <= n; i++)scanf("%lf%d%d%d",&a[i].f,&a[i].x,&a[i].y,&a[i].r);sort(a+1,a+n+1);for(int i = 1; i <= n; i++){for(int j = 1; j < i; j++)if(inarea(i,j)){g[j+n].push_back(E(i,1,g[i].size()));g[i].push_back(E(j+n,0,g[j+n].size()-1));}}g[1].push_back(E(1+n,0x3f3f3f3f,g[1+n].size()));g[1+n].push_back(E(1,0,g[1].size()-1));g[n].push_back(E(2*n,0x3f3f3f3f,g[2*n].size()));g[2*n].push_back(E(n,0,g[n].size()-1));for(int i = 2; i < n; i++){g[i].push_back(E(i+n,1,g[i+n].size()));g[i+n].push_back(E(i,0,g[i].size()-1));}s = 1,t = 2*n;sap();if(flow >= 2)printf("Game is VALID\n");else printf("Game is NOT VALID\n");for(int i = 1; i <= t; i++) g[i].clear();}
}

HDU4183 Pahom on Water(最大流)相关推荐

  1. HDU4183 Pahom on Water(来回走最大流,一个点只经过一次)

    题意: 有n个圆,每个圆的中心和半径和一个频率都给定,只有一个频率最高的789为紫色,只有一个最低的400为红色,规则如下: 1.当两个圆严格相交时,且人是从红色到紫色的方向运动时可以由低频率向高频率 ...

  2. HDU4183 Pahom on Water(网络流之最大流)

    题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4183 题意:给你n个点,每个点有一个频率,原点坐标和半径,i到j可达当且仅当i的频率小于j的频率并且两 ...

  3. hdu 4183 Pahom on Water 最大流

    一个平面上有n个圆, 每个圆都有一个频率, 有两个频率为400和789的圆, 问是否能从频率为400的圆走到频率为789的圆, 并从频率为789的圆走回频率为400的圆, 并且除了频率为400的圆, ...

  4. HDU 4183 Pahom on Water 来回走不重复点的网络流

    题目来源:HDU 4183 Pahom on Water 题意:若干个区域 每个区域有一个值 区域是圆 给出圆心和半径 从起点(值为400.0)到终点(值为789.0)满足走相交的圆 并且值必须递增 ...

  5. HDU -- 4183 Pahom on Water(最大流)

    题目大意: 二维空间上有一些点,每个点有一个频率,圆心坐标,半径,设s点是频率最低的点,t是频率最高的点,要求从s点走到t点,在从点t回到点s.当从s走到t时,要求两个点表示的园相交并且第一个点的频率 ...

  6. hdu 4183 Pahom on Water 网络流

    题意   二维空间上有一些点,每个点有一个半径r和频率f,要从某一个点S走到另一个点T,然后再从T回到S.从S到T时,如果两个点表示的圆相交并且第一个点小于第二个点的频率的,那么能从第一个点到第二个点 ...

  7. 【网络流】 HDU 4183 Pahom on Water 拆点

    题意:求两条路 能从 400.0 -> 789.0 且这两条路不想交(除了端点400,789 ) 求只能走一次的网络流需要用到拆点, 将点i  拆成 i 和 i+n  i->i+n的容量为 ...

  8. HDU 4183 Pahom on Water(点双连通分量)

    题意:有很多的被涂上颜色的呈圆形的垫子,一些垫子可以有相同的颜色,但是红色和紫罗兰只有一个,垫子摆放的时候可以相交,初始一个人站在红垫子上,这个人要从红垫子走到紫罗兰垫子,然后再从紫罗兰垫子走到红垫子 ...

  9. 【HDOJ】4183 Pahom on Water

    就是一个网络流.red结点容量为2,查看最大流量是否大于等于2.对于条件2,把边反向加入建图.条件1,边正向加入建图. 1 /* 4183 */ 2 #include <iostream> ...

最新文章

  1. 函数计算新功能-----支持C#函数
  2. java是什么 需要学什么_Java是什么,Java需要学习哪些内容?如何自学Java?
  3. 第七章、Linux 文件与目录管理
  4. 2016年蓝桥杯省赛题解
  5. linux命令:groupdel
  6. 【Linux】一步一步学Linux——logname命令(109)
  7. ant external lib
  8. HDFS写入和读取过程
  9. php 服务器安装,php服务器安装笔记
  10. 安卓应用安全指南 4.1.1 创建/使用活动 示例代码
  11. js产生页面内的顺序序列号
  12. sql数值计算函数ceil(x)、sign(X)、sqrt(X)、truncate(X,D)、floor(x)、pi()、mod(x,y)
  13. mysql如何通过数据库修改root_MySQL数据库之MySQL——修改root密码的4种方法(以windows为例)...
  14. 微服务实战之Prometheus使用分享
  15. 54.用环信实现聊天功能
  16. Java单链表中的元素互换位置_Java如何在链表的第一个和最后一个位置添加一个元素?...
  17. 分布式网络爬虫功能模块组成
  18. 谈一下对计算机网络技术的认识,浅谈对计算机网络的认识
  19. Win10 最下面的任务栏不显示正在打开的窗口了,打开任何东西任务栏都不显示
  20. U-GAT-IT 论文翻译

热门文章

  1. 浮点数规格化与定点数
  2. 判断txt文件是否为空
  3. 日期转换工具+获取当年节假日信息 很简单
  4. 飞鸽传书源码分析三-网络
  5. vue+大文件上传控件
  6. linux 压力测试工具之ab
  7. vue.js高仿饿了吗实现tips
  8. 如果不用为生活奔波,我愿意成为一个自由作家
  9. R语言编程学习之函数与模型:VAR与SVAR和爬虫(图)
  10. 《精益开发与看板方法》读书笔记