【SDOI2015第1轮第2试】星际战争

#include<cstdio>
#include<queue>
using namespace std;

const int M = 10000;
const double inf = 1e18;
int n , m , h[505] , cur[505] , dep[505] , s , t , tot = 1;
double a[55] , b[55] , ans , Max;
struct edge{
    int to , nxt;
    double w;
}e[M + 5] , ee[M + 5];

inline double min(double x , double y) {return x < y ? x : y;};

inline void add(int x , int y , double w)
{
    e[++tot].to = y;
    e[tot].w = w;
    e[tot].nxt = h[x];
    h[x] = tot;
}

inline int bfs(int s , int t)
{
    for(register int i = s; i <= t; i++) dep[i] = 0 , cur[i] = h[i];
    queue<int> Q;
    dep[s] = 1;
    Q.push(s);
    while (!Q.empty())
    {
        int now = Q.front();
        Q.pop();
        for(register int i = h[now]; i; i = ee[i].nxt)
        {
            int v = ee[i].to;
            if (ee[i].w <= 0 || dep[v] != 0) continue;
            dep[v] = dep[now] + 1;
            Q.push(v);
        }
    }
    return dep[t];
}

inline double dfs(int x , int fa , double mi)
{
    if (x == t || mi <= 0) return mi;
    double flow = 0;
    for(register int i = cur[x]; i; i = ee[i].nxt)
    {
        cur[x] = i;
        int v = ee[i].to;
        if (v == fa || dep[x] + 1 != dep[v] || ee[i].w <= 0) continue;
        double f = dfs(v , x , min(mi , ee[i].w));
        if (f <= 0) continue;
        mi -= f , ee[i].w -= f , ee[i ^ 1].w += f , flow += f;
        if (mi <= 0) break;
    }
    return flow;
}

inline bool check(double mid)
{
    for(register int i = 1; i <= tot; i++) ee[i] = e[i];
    for(register int i = h[s]; i; i = ee[i].nxt)
        ee[i].w = b[ee[i].to] * mid;
    double res = 0;
    while (bfs(s , t)) res += dfs(s , 0 , inf);
    return res >= Max;
}

int main()
{
//  freopen("星际战争.in" , "r" , stdin);
    scanf("%d%d" , &n , &m);
    t = n + m + 5;
    for(register int i = 1; i <= n; i++)
    {
        scanf("%lf" , &a[i]);
        Max += a[i];
        add(i + m , t , a[i]);
        add(t , i + m , 0);
    }
    for(register int i = 1; i <= m; i++)
    {
        scanf("%lf" , &b[i]);
        add(s , i , b[i]);
        add(i , s , 0);
    }
    int x;
    for(register int i = 1; i <= m; i++)
        for(register int j = 1; j <= n; j++)
        {
            scanf("%d" , &x);
            if (x == 1) add(i , j + m , inf) , add(j + m , i , 0);
        }
    double l = 0 , r = 1e9 , mid;
    for(register int i = 1; i <= 60; i++)
    {
        mid = (l + r) * 0.5;
        if (check(mid)) r = mid , ans = mid;
        else l = mid;
    }
    printf("%.6lf" , ans);
}

原文地址:https://www.cnblogs.com/leiyuanze/p/12337108.html

时间: 2024-10-11 02:46:24

【SDOI2015第1轮第2试】星际战争的相关文章

【SDOI2015第1轮第1试】排序

#include<cstdio> #include<iostream> using namespace std; typedef long long LL; const int N = 1 << 13; int n , a[N]; LL ans , fac[13]; inline bool check(int len) { for(register int i = 1; i <= 1 << n - len; i++) if (a[(i - 1) * (

【SDOI2015第1轮第1试】寻宝游戏

#include<cstdio> #include<set> using namespace std; typedef long long LL; const int N = 1e5; int top[N + 5] , dfn[N + 5] , rev[N + 5] , fa[N + 5] , size[N + 5] , son[N + 5] , dep[N + 5]; LL dis[N + 5] , ans , now; int vis[N + 5] , h[N + 5] , n

【BZOJ3993】[SDOI2015]星际战争 二分+最大流

[BZOJ3993][SDOI2015]星际战争 Description 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到0或者以下时,这个巨型机器人就被摧毁了.X军团有M个激光武器,其中第i个激光武器每秒可以削减一个巨型机器人Bi的装甲值.激光武器的攻击是连续的.这种激光武器非常奇怪,一个激光武器只能攻击一些特定的敌人.Y军团看到自己的巨型机器人被X

luogu P3324 [SDOI2015]星际战争

二次联通门 : luogu P3324 [SDOI2015]星际战争 /* luogu P3324 [SDOI2015]星际战争 之前总是TLE 结果改了改Max的值就过了... 最大流 二分时间 源点与武器连边 装甲与汇点连边 武器再与装甲连边 把 时间 * 攻击作为边权,跑最大流 判断最后的流是否大于装甲的总和 */ #include <algorithm> #include <iostream> #include <cstring> #include <cs

3993: [SDOI2015]星际战争

3993: [SDOI2015]星际战争 Time Limit: 10 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 1244  Solved: 560[Submit][Status][Discuss] Description 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到0或者以下时,这个巨型

[SDOI2015][BZOJ3993] 星际战争

3993: [SDOI2015]星际战争 Time Limit: 10 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 201  Solved: 119[Submit][Status][Discuss] Description 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到0或者以下时,这个巨型机

【BZOJ 3993】 [SDOI2015]星际战争

3993: [SDOI2015]星际战争 Time Limit: 10 Sec Memory Limit: 128 MBSec Special Judge Submit: 180 Solved: 108 [Submit][Status][Discuss] Description 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到0或者以下时,这个巨型机器

BZOJ 3993 [SDOI2015]星际战争

题解:二分+网络流判定. #include<iostream> #include<cstdio> #include<cstring> #include<cstdlib> #include<string> #include<cmath> #include<ctime> #include<algorithm> #include<map> #include<set> #include<q

BZOJ3993 [SDOI2015]星际战争

二分答案...然后最大流验证是否可行... 没了,好水啊QAQ 1 /************************************************************** 2 Problem: 3993 3 User: rausen 4 Language: C++ 5 Result: Accepted 6 Time:40 ms 7 Memory:1156 kb 8 ******************************************************