[bzoj3993][SDOI2015]星际战争-二分+最大流
Brief Description
3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战。在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai。当一个巨型机器人的装甲值减少到0或者以下时,这个巨型机器人就被摧毁了。X军团有M个激光武器,其中第i个激光武器每秒可以削减一个巨型机器人Bi的装甲值。激光武器的攻击是连续的。这种激光武器非常奇怪,一个激光武器只能攻击一些特定的敌人。Y军团看到自己的巨型机器人被X军团一个一个消灭,他们急需下达更多的指令。为了这个目标,Y军团需要知道X军团最少需要用多长时间才能将Y军团的所有巨型机器人摧毁。但是他们不会计算这个问题,因此向你求助。
Algorithm Design
明明是非常水的套路题却卡了很久, 看来是太长时间没有做网络流的题目手生了, 我真的是思博啊, 我这样的人就应该早点滚粗吧Orz
我们考虑直接二分答案, 这样所有武器能输出的最大火力就有了, 按照火力建模, 随便搞搞就有了.
我真是思博啊.
数组开小了...然后不爽一下子开150万就过了Orz
Code
#include <algorithm>
#include <cmath>
#include <cstdio>
#include <queue>
const double eps = 1e-9;
#define ld long double
const int maxn = 110 << 1;
const int inf = 0x3f3f3f;
struct edge {
int to, next;
ld cap;
edge(int a = 0, int b = 0, ld c = 0) : to(a), next(b), cap(c) {}
} e[1500005];
int cnt = 1, n, m, s, t, v;
ld L, R;
int head[maxn], mi[maxn], A[maxn], B[maxn], tod;
ld dist[maxn];
void add_edge(int u, int v, ld c) {
e[++cnt] = edge(v, head[u], c);
head[u] = cnt;
}
void add(int u, int v, ld c) {
add_edge(u, v, c);
add_edge(v, u, 0);
}
void bfs(int s) {
std::fill(dist, dist + v, -1);
dist[s] = 0;
std::queue<int> q;
q.push(s);
while (!q.empty()) {
int u = q.front();
q.pop();
for (int i = head[u]; i; i = e[i].next) {
if (dist[e[i].to] == -1 && e[i].cap > eps) {
dist[e[i].to] = dist[u] + e[i].cap;
q.push(e[i].to);
}
}
}
}
ld dfs(int s, int t, ld flow) {
if (s == t)
return flow;
for (int i = head[s]; i; i = e[i].next) {
// printf("%.2f ", e[i].cap);
if (e[i].cap > eps && dist[e[i].to] > dist[s]) {
ld d = dfs(e[i].to, t, std::min(e[i].cap, flow));
if (d > eps) {
e[i].cap -= d;
e[i ^ 1].cap += d;
return d;
}
}
}
return 0;
}
ld dinic(int s, int t) {
ld flow = 0;
while (1) {
bfs(s);
if (dist[t] == -1)
return flow;
ld d;
while ((d = dfs(s, t, inf)))
flow += d;
}
return flow;
}
bool check(ld mid) {
for (int i = 2; i <= cnt; i += 2)
e[i].cap += e[i ^ 1].cap, e[i ^ 1].cap = 0;
for (int i = head[s]; i; i = e[i].next)
e[i].cap = mid * B[e[i].to];
ld flow = dinic(s, t);
return std::fabs(flow - (ld)tod) <= eps;
}
int main() {
#ifndef ONLINE_JUDGE
freopen("input", "r", stdin);
#endif
scanf("%d %d", &n, &m);
s = 0, t = n + m + 1, v = t + 1, L = 0, R = 0;
for (int i = 1; i <= n; i++) {
scanf("%d", &A[i]);
mi[i] = inf;
}
for (int i = 1; i <= m; i++)
scanf("%d", &B[i]);
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
int x;
scanf("%d", &x);
if (x == 1) {
add(i, j + m, inf);
mi[j] = std::min(mi[j], B[i]);
}
}
add(0, i, inf);
}
for (int i = 1; i <= n; i++) {
R += A[i] / mi[i];
add(i + m, t, A[i]);
tod += A[i];
}
// printf("%d\n", tod);
R = 5e6;
while (R - L > eps) {
ld mid = (L + R) / 2;
if (check(mid))
R = mid;
else
L = mid;
}
printf("%.7Lf", (L + R) / 2);
}
[bzoj3993][SDOI2015]星际战争-二分+最大流的更多相关文章
- 【BZOJ3993】[SDOI2015]星际战争 二分+最大流
[BZOJ3993][SDOI2015]星际战争 Description 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地 ...
- bzoj千题计划131:bzoj3993: [SDOI2015]星际战争
http://www.lydsy.com/JudgeOnline/problem.php?id=3993 二分答案 源点向武器连 mid*攻击力的边 机器人向汇点连 防御力 的边 武器i能攻击机器人j ...
- BZOJ 3993: [SDOI2015]星际战争 [二分答案 二分图]
3993: [SDOI2015]星际战争 题意:略 R1D2T1考了裸二分答案+二分图最大匹配... #include <iostream> #include <cstdio> ...
- bzoj3993: [SDOI2015]星际战争(网络流)
3993: [SDOI2015]星际战争 题目:传送门 题解: 洛谷AC了,但是因为bzoj的spj有问题所以暂时没A 一道老题目了,二分时间然后网络流判断. 每次st-->武器连时间*攻击力 ...
- 【二分答案】【最大流】bzoj3993 [Sdoi2015]星际战争
二分Time,S->炮[i]:Time*b[i] 炮[i]->机器人[i]:INF 机器人[i]->T:a[i]. 判断是否满流. #include<cstdio> #i ...
- [SDOI2015][bzoj3993] 星际战争 [二分+最大流]
题面 传送门 思路 首先,有一个非常明显的模型: 将激光武器放到一边,机器人放到另一边,从每一个激光武器向它可以攻击的机器人连边,形成一个二分图 建立附加源点$ss$和附加汇点$tt$,$ss$连所有 ...
- bzoj3993: [SDOI2015]星际战争(二分+最大流)
题目描述 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战. 在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值 ...
- BZOJ3993 [SDOI2015]星际战争 【二分 + 网络流】
题目 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到 ...
- BZOJ3993 [SDOI2015]星际战争
二分答案...然后最大流验证是否可行... 没了,好水啊QAQ /************************************************************** Prob ...
随机推荐
- C#控件DropDownList下拉列表默认打开
c#中的控件DropDownList要实现默打开确实不容易,之前也是想过页面上的点击之后就打开了,那直接模拟点击不就行了,试过后大失所望,根本没有效果. 于是网上找到了一个例子能实现IE浏览器下的打开 ...
- 3dContactPointAnnotationTool开发日志(十六)
调了一上午才发现是把下面这个函数: private float DivideTriangle(int []triangle,out int []outTriangle,List<Vector ...
- hadoop下安装mysql
http://www.cnblogs.com/zhuyp1015/p/3561470.html 第一步:先把这个文件放入到linux环境下桌面. 接着编写脚本:sudo apt-get u ...
- Bootstrap 轮播图的使用和理解
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8& ...
- 【.Net】Visual Studio的调试技巧
这是我写的关于VS2010和.Net4发布的博客系列的第26篇. 今天的博文包含了一些有用的能用于VS的调试技巧. 我的朋友Scott Cate(他写了很多很好的关于VS使用技巧和窍门的博客)最近向我 ...
- cookie的路径决定服务器在发送请求时候 是否决定发送 当路径匹配时候 则发送给服务器(默认发送原则)
1.cookie路径默认为当前访问地址的上一级路径 2.当前访问地址的路径包含了cookie的路径 则发送给访问的地址 3.路径决定cookie发送与否 4.发送包含在当前路径里面的cookie
- bzoj3168-钙铁锌硒维生素
题目 这道题的题意理解很重要,直接写原题了. 小林把人体需要的营养分成了\(n\)种,他准备了2套厨师机器人,一套厨师机器人有\(n\)个,每个厨师机器人只会做一道菜,这道菜一斤能提供第\(i\)种营 ...
- 【刷题】洛谷 P2764 最小路径覆盖问题
题目描述 «问题描述: 给定有向图G=(V,E).设P 是G 的一个简单路(顶点不相交)的集合.如果V 中每个顶点恰好在P 的一条路上,则称P是G 的一个路径覆盖.P 中路径可以从V 的任何一个顶点开 ...
- 用Matlab对数据进行线性拟合算法
http://www.cnblogs.com/softlin/p/5965939.html 挖坑
- IntelliJ IDEA 详细图解最常用的配置 ,适合新人,解决eclipse转idea的烦恼
刚刚使用IntelliJ IDEA 编辑器的时候,会有很多设置,会方便以后的开发,磨刀不误砍柴工. 比如:设置文件字体大小,代码自动完成提示,版本管理,本地代码历史,自动导入包,修改注释,修改tab的 ...