hihocoder-1389&&2016北京网赛07 Sewage Treatment(二分+网络流)
题目链接:
Sewage Treatment
描述
After years of suffering, people could not tolerate the pollution in the city any more, and started a long-lasting protest. Eventually, the municipal government made up its mind to deal with the sewage discharged by factories. The government planned to deploy some Pollution-Killer Utilities (PKUs) in order to clean all the sewage, and meanwhile, minimize the total cost.
The city can be approximately considered as a plane. There are n factories discharging sewage. The i-th one is located at (xi, yi), and discharges si units of sewage every day. The government has built m PKUs. The PKUs' locations are also fixed, and the j-th one is located at (xj, yj). Two features of PKUs are essential, and you will need to find the best choice of them: u is the upper limit of units of sewage that can be cleaned by one PKU every day, and c is the coverage radius of one PKU (which means, only if the distance between the PKU and the factory does not exceed the coverage radius, sewage discharged by this factory can be cleaned by this PKU). Note that all the PKUs share the same u and c. Because of some technical reasons, u has to be a positive integer.
Here is your task. The cost of deploying these PKUs can be weighed by an empirical formula:
f = u×sqrt(c)
You need to calculate the minimum value of f, and guarantee all the sewage is treated.
输入
There are no more than 15 test cases. Each test case starts with a line containing two positive integers n and m (1 <= n, m <= 100), representing the number of factories and PKUs. Then n lines follow, the i-th line contains three integers xi, yi, si (-10000 <= xi, yi <= 10000, 1 <= si <= 100), representing the i-th factory's location and the quantity of sewage discharged by it every day. In the next following m lines, the j-th line contains two integers xj, yj (-10000 <= xj, yj <= 10000), representing the j-th PKU's location. After each test case there is an empty line. After all the test cases there is a line "0 0", which indicates the end of the input, and should not be processed.
输出
For each test case, output a single line containing a number, which is the minimum value of f. This number should be rounded to an integer.
提示
Test case 1:
When u = 12 and c = 2, f has the minimum value of 12 * sqrt(2) = 16.97 = 17.
Test case 2:
When u = 10, c = sqrt(2), f has the minimum value of 10 * sqrt(sqrt(2)) = 11.89 = 12.
The input guarantees that there is always a valid solution. You may assume that the factories and PKUs are uniformly randomly distributed on the plane.
- 样例输入
-
3 1
-1 0 5
2 0 3
0 1 4
0 0 4 2
0 0 4
3 0 5
3 2 3
0 2 6
1 1
2 1 0 0 - 样例输出
-
17
12 题意: 给出n个工厂,每个工厂的坐标和每天产生的污水量,再给m个pku,现在要求f=u*sqrt(r)的最小值,要求所有的污水都处理完;
只有工厂的与pku的距离<=r时这个工厂的污水才能给pku处理,而且给的量是任意的,而且所有的u和r是一样的; 思路: 枚举所有的距离,然后二分u,建图的时候源点s到所有的工厂连边,容量为每天产生的污水量,所有的pku到汇点连边,容量为u,然后相距<=r的pku与工厂连边,容量无穷;
跑最大流看是否==sum;
AC代码:#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <bits/stdc++.h>
#include <stack>
#include <map> using namespace std; #define For(i,j,n) for(int i=j;i<=n;i++)
#define mst(ss,b) memset(ss,b,sizeof(ss)); typedef long long LL; template<class T> void read(T&num) {
char CH; bool F=false;
for(CH=getchar();CH<'0'||CH>'9';F= CH=='-',CH=getchar());
for(num=0;CH>='0'&&CH<='9';num=num*10+CH-'0',CH=getchar());
F && (num=-num);
}
int stk[70], tp;
template<class T> inline void print(T p) {
if(!p) { puts("0"); return; }
while(p) stk[++ tp] = p%10, p/=10;
while(tp) putchar(stk[tp--] + '0');
putchar('\n');
} const LL mod=1e9+7;
const double PI=acos(-1.0);
const int inf=1e9;
const int N=(1<<20)+10;
const int maxn=205;
const double eps=1e-12; struct Edge
{
int from,to,cap,flow;
};
vector<Edge>edge;
vector<int>G[maxn];
bool vis[maxn];
int cur[maxn],n,m,fn,s,t,d[maxn];
int dis[210][210];
int x[maxn],y[maxn],fs[maxn],sum,lower,upper,cnt;
double ans;
struct po
{
int from,to,dis;
}a[105*105];
int cmp(po u,po v)
{
return u.dis<v.dis;
}
inline void add_edge(int from,int to,int cap)
{
edge.push_back((Edge){from,to,cap,0});
edge.push_back((Edge){to,from,0,0});
m=edge.size();
G[from].push_back(m-2);
G[to].push_back(m-1);
}
bool bfs()
{
mst(vis,0);
queue<int>Q;
Q.push(s);
d[s]=0;
vis[s]=1;
while(!Q.empty())
{
int x=Q.front();Q.pop();
int len=G[x].size();
for(int i=0;i<len;i++)
{
Edge& e=edge[G[x][i]];
if(!vis[e.to]&&e.cap>e.flow)
{
vis[e.to]=1;
d[e.to]=d[x]+1;
Q.push(e.to);
}
}
}
return vis[t];
} int dfs(int x,int a)
{
if(x==t||a==0)return a;
int flow=0,f,len=G[x].size();
for(int& i=cur[x];i<len;i++)
{
Edge& e=edge[G[x][i]];
if(d[x]+1==d[e.to]&&(f=dfs(e.to,min(a,e.cap-e.flow)))>0)
{
e.flow+=f;
edge[G[x][i]^1].flow-=f;
flow+=f;
a-=f;
if(a==0)break;
}
}
return flow;
} int maxflow()
{
int flow=0;
while(bfs())
{
mst(cur,0);
flow+=dfs(s,inf);
}
return flow;
}
inline void Init(int k,int hi)
{
edge.clear();
for(int i=0;i<=t;i++)G[i].clear();
for(int i=1;i<=k;i++)
{
add_edge(a[i].from,a[i].to,inf);
}
for(int i=k+1;i<=cnt;i++)
{
if(a[i].dis>a[k].dis)break;
add_edge(a[i].from,a[i].to,inf);
}
for(int i=1;i<=n;i++)add_edge(s,i,fs[i]);
for(int i=n+1;i<=n+fn;i++)add_edge(i,t,hi);
}
inline int check(int k,int flow)
{
Init(k,flow);
int ans=maxflow();
if(ans==sum)return 1;
return 0;
}
double solve(int k)
{
double dist=sqrt(sqrt(a[k].dis*1.0));
int l=lower,r=min(upper,(int)(ceil(ans/dist)));
while(l<r)
{
int mid=(l+r)>>1;
if(check(k,mid))r=mid;
else l=mid+1;
}
upper=r;
return dist*r;
}
int main()
{
while(1)
{
read(n);read(fn);
if(!n&&!fn)break;
sum=0;
for(int i=1;i<=n;i++)
{
read(x[i]);read(y[i]);read(fs[i]);
sum=sum+fs[i];
}
for(int i=n+1;i<=n+fn;i++)
{
read(x[i]);read(y[i]);
}
cnt=0;
for(int i=1;i<=n;i++)
{
for(int j=n+1;j<=n+fn;j++)
{
int dist=(x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]);
a[++cnt].from=i;
a[cnt].to=j;
a[cnt].dis=dist;
}
}
sort(a+1,a+cnt+1,cmp);
a[0].dis=-1;
s=0,t=n+fn+1;
ans=inf;
lower=(sum+fn-1)/fn,upper=1e4;
for(int i=1;i<=cnt;i++)
{
if(a[i].dis==a[i-1].dis)continue;
double temp=solve(i);
ans=min(temp,ans);
}
printf("%.0lf\n",ans);
}
return 0;
}
hihocoder-1389&&2016北京网赛07 Sewage Treatment(二分+网络流)的更多相关文章
- hihoCoder1388 Periodic Signal(2016北京网赛F:NTT)
题目 Source http://hihocoder.com/problemset/problem/1388 Description Profess X is an expert in signal ...
- hihoCoder 1391 Countries【预处理+排序+优先队列】2016北京网络赛
题目:http://hihocoder.com/problemset/problem/1391 题目大意: A和B两个国家互射导弹,每个国家都有一个防御系统,在防御系统开启的时间内可以将到达本国的导弹 ...
- ACM学习历程—Hihocoder 1233 Boxes(bfs)(2015北京网赛)
hihoCoder挑战赛12 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 There is a strange storehouse in PKU. In this ...
- 2016北京网络赛 hihocoder 1391 Countries 树状数组
Countries 描述 There are two antagonistic countries, country A and country B. They are in a war, and ...
- 北京网赛I题 hiho1391 (树状数组、区间覆盖最大值问题)
题目链接:http://hihocoder.com/problemset/problem/1391 题意:A国和B国向对方分别投射N枚和M枚导弹(发射时间,飞行时间,伤害值),同时两国各自都有防御系统 ...
- 2015年北京网赛 boxes(bfs)
题目链接: http://hihocoder.com/problemset/problem/1233 题目描述: 给定最多七个箱子,每个箱子的重量都不相同,每次都可以将一个箱子放在相邻的位置上,如果相 ...
- hihocoder-1391&&北京网赛09 Countries(优先队列)
题目链接: Countries 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 There are two antagonistic countries, country ...
- hihocoder 1236(2015北京网络赛 J题) 分块bitset乱搞题
题目大意: 每个人有五门课成绩,初始给定一部分学生的成绩,然后每次询问给出一个学生的成绩,希望知道在给定的一堆学生的成绩比这个学生每门都低或者相等的人数 因为强行要求在线查询,所以题目要求,每次当前给 ...
- hiho 1227 找到一个恰好包含n个点的圆 (2015北京网赛 A题)
平面上有m个点,要从这m个点当中找出n个点,使得包含这n个点的圆的半径(圆心为n个点当中的某一点且半径为整数)最小,同时保证圆周上没有点. n > m 时要输出-1 样例输入43 2 0 0 1 ...
随机推荐
- 线段树的区间更新---A Simple Problem with Integers
POJ 3468 Description 给出了一个序列,你需要处理如下两种询问. "C a b c"表示给[a, b]区间中的值全部增加c (-10000 ≤ c ≤ 100 ...
- [PHP] 读取大文件并显示
使用PHP读取日志文件,当文件比较大的时候,会报内存不足,因此应该部分读取,读取指定的行数的数据 PHP代码: <?php class Test{ //日志路径 const LOG_PATH=& ...
- Mysql的简单使用(三)
接上文Mysql的简单使用(二) mysql中结构相同的两个表进行合并:(注意需要两个表的结构是一样的) 有如下结构的两个表father和person. 合并的步骤为: 1.把person表和fath ...
- PHP imagecopyresampled 参数图示
- [CLK Framework] CLK.Threading.PortableTimer - 跨平台的Timer类别
[CLK Framework] CLK.Threading.PortableTimer - 跨平台的Timer类别 问题情景 开发应用程式的时候,免不了需要加入一些定时执行的设计,例如说:定时更新画面 ...
- JavaScript中的null与nudefined
null和undefined 概述 null与undefined都可以表示"没有",含义非常相似.将一个变量赋值为undefined或null,老实说,语法效果几乎没区别. var ...
- Android Service获取当前位置(GPS+基站)
需求详情:1).Service中每隔1秒执行一次定位操作(GPS+基站)2).定位的结果实时显示在界面上(要求得到经度.纬度)技术支持:1).获取经纬度通过GPS+基站获取经纬度,先通过GPS来获取, ...
- Atitit.atiInputMethod v2词库清理策略工具 q229
Atitit.atiInputMethod v2词库清理策略工具 q229 1.1. Foreigncode 外码清理1 1.2. 垃圾词澄清1 1.1. Foreigncode 外码清理 On ...
- sudo gem install cocoapods 没反应问题
1. 尝试更新 sudo gem update --system 2. 查看安装详细 sudo gem install cocoapods -V 3.详细使用有个链接 http://blog.csdn ...
- GridView总结二:GridView自带编辑删除更新
GridView自带编辑删除更新逻辑很简单:操作完,重新绑定.总结总结,防止忘记... 效果图: 前台代码: <%@ Page Language="C#" AutoEvent ...