首页 > 其他分享 >P2762 太空飞行计划问题

P2762 太空飞行计划问题

时间:2023-12-11 19:11:38浏览次数:32  
标签:fir cnt int st 计划 P2762 include 太空飞行 dis

题意

有 \(n\) 个工作,每个工作需要一些限制。

你可以花 \(s_i\) 的代价满足一个限制。

然后获得 \(h_i\) 的贡献。

问是的获得的贡献最大可以使多少?

Sol

最小割。

从源点往每个实验连 \(h_i\),每个实验往每个代价连 \(inf\).

代价往汇点连 \(s_i\) 就行了。

Code

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <array>
#include <queue>
#include <vector>
#include <bitset>
#include <cstring>
#define int long long
#define pii pair <int, int>
using namespace std;
// #ifdef ONLINE_JUDGE

// #define getchar() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 1 << 21, stdin), p1 == p2) ? EOF : *p1++)
// char buf[1 << 23], *p1 = buf, *p2 = buf, ubuf[1 << 23], *u = ubuf;

// #endif
int read() {
    int p = 0, flg = 1;
    char c = getchar();
    while (c < '0' || c > '9') {
        if (c == '-') flg = -1;
        c = getchar();
    }
    while (c >= '0' && c <= '9') {
        p = p * 10 + c - '0';
        c = getchar();
    }
    return p * flg;
}
void write(int x) {
    if (x < 0) {
        x = -x;
        putchar('-');
    }
    if (x > 9) {
        write(x / 10);
    }
    putchar(x % 10 + '0');
}

#define fi first
#define se second

const int N = 1005, M = 10005, inf = 2e18;

namespace G {

array <int, N> fir;
array <int, M> nex, to, cap;
int cnt = 1;
void add(int x, int y, int z) {
    cnt++;
    nex[cnt] = fir[x];
    to[cnt] = y;
    cap[cnt] = z;
    fir[x] = cnt;
}
void _add(int x, int y, int z) {
    add(x, y, z);
    add(y, x, 0);
}

}

namespace Mfl {

array <int, N> cur, dis;
queue <int> q;

bool bfs(pii st) {
    dis.fill(-1), dis[st.fi] = 0;
    q.push(st.fi);
    while (!q.empty()) {
        int u = q.front();
        q.pop();
        for (int i = G::fir[u]; i; i = G::nex[i]) {
            if (!G::cap[i] || ~dis[G::to[i]]) continue;
            dis[G::to[i]] = dis[u] + 1, q.push(G::to[i]);
        }
    }
    return ~dis[st.se];
}

int dfs(int x, int augcd, pii st) {
    if (x == st.se) return augcd;
    int augc = augcd;
    for (int &i = cur[x]; i; i = G::nex[i]) {
        if (!G::cap[i] || dis[G::to[i]] <= dis[x]) continue;
        int flow = dfs(G::to[i], min(augc, G::cap[i]), st);
        augc -= flow;
        G::cap[i] -= flow, G::cap[i ^ 1] += flow;
        if (!augc) break;
    }
    return augcd - augc;
}

int dinic(pii st) {
    int ans = 0;
    while (bfs(st)) {
        copy(G::fir.begin(), G::fir.end(), cur.begin());
        ans += dfs(st.fi, inf, st);
    }
    return ans;
}

}

bitset <N> vis;

void dfs(int x) {
    vis[x] = 1;
    for (int i = G::fir[x]; i; i = G::nex[i]) {
        if (!G::cap[i] || vis[G::to[i]]) continue;
        dfs(G::to[i]);
    }
}

char tools[10000]; 
signed main() {
    int n, m; scanf("%d%d", &m, &n);
    pii st = make_pair(n + m + 1, n + m + 2);
    int ans = 0;
    for (int i = 1; i <= m; i++) {
        int x; scanf("%d", &x);
        ans += x;
        G::_add(st.fi, i + n, x);
        memset(tools, 0, sizeof tools);
        cin.getline(tools, 10000); int ulen = 0,tool;
        while (sscanf(tools + ulen,"%d", &tool) == 1) {
            G::_add(i + n, tool, inf);
            if (tool == 0) ulen++;
            else while (tool) tool /= 10, ulen++;
            ulen++;
        }
    }
    for (int i = 1; i <= n; i++) {
        int x; scanf("%d", &x);
        G::_add(i, st.se, x);
    }
    ans = ans - Mfl::dinic(st); dfs(st.fi);
    for (int i = n + 1; i <= n + m; i++)
        if (vis[i]) write(i - n), putchar(32);
    puts("");
    for (int i = 1; i <= n; i++)
        if (vis[i]) write(i), putchar(32);
    puts("");
    write(ans), puts("");
    return 0;
}

标签:fir,cnt,int,st,计划,P2762,include,太空飞行,dis
From: https://www.cnblogs.com/cxqghzj/p/17895290.html

相关文章

  • 计划
    一、大目标换工作or创业认知、扩大社交运动健身结婚买房 二、拆分成小目标1.换工作充电持续集成方面的知识流程(预编译、检查、单元测试、自动化测试、集成测试、系统测试等)pipeline+测试用例编写运用共享库完成多个项目统一流程的目标(2天)......
  • 计划任务与日志
    [root@localhost~]#systemctlenablecrond[root@localhost~]#psaux|grepcrondroot62420.30.01263801656?Ss16:270:00/usr/sbin/crond-ncrond进程每分钟会处理一次计划任务存储位置[root@localhost~]#ls/var/spool/cron......
  • Vue学习计划-Vue2--Vue核心(五)条件、列表渲染、表单数据
    1.条件渲染v-ifv-if="表达式"v-else-if="表达式"v-else="表达式"适用于:切换频率较低的场景特点:不显示dom元素,直接被删除注意:v-if和v-else-if、v-else一起使用,但要求结构不能被打断v-if和template一起使用,v-show不可以v-showv-show="表达式"适用于:切换频......
  • 制定验证计划和分层的验证平台
    内容module/block有100个feature,验证需要有1000个test,需要有计划,按照节点进行验证策略验证RTLcode和designspec一致性资源:VCSlicense/磁盘空间验证内容:功能验证验证结束-testpass/coverage验证进度验证计划内容验证的功能点和testcase是验证计划中最重......
  • 天池AI练习生计划 - 第二期AI数学基础入门与实践,火热进行中!通关赢取双重礼品!
    机器视觉学术研究与产品研发专家雷明,带领您详细学习人工智能领域需要用到的数据知识点,从学习者蜕变为AI新星!轻松来闯关,即可领取双重礼品~实训培训证书:通关两个关卡即可领取阿里云定制长袖T恤:通关全部关卡即可领取活动地址:https://tianchi.aliyun.com/specials/promotion/math......
  • 天池AI练习生计划 - 第二期AI数学基础入门与实践,火热进行中!通关赢取双重礼品!
    机器视觉学术研究与产品研发专家雷明,带领您详细学习人工智能领域需要用到的数据知识点,从学习者蜕变为AI新星!轻松来闯关,即可领取双重礼品~实训培训证书:通关两个关卡即可领取阿里云定制长袖T恤:通关全部关卡即可领取活动地址:https://tianchi.aliyun.com/specials/promotion/math......
  • SQL SERVER 查看sql执行计划
    SQLSERVER是Transact-SQL和mysql差别还蛮大的语法SETSHOWPLAN_ALL{ON|OFF}SETSHOWPLAN_ALLON  是开启执行计划,在这个查询下的sql会返回执行信息,需要提前且单独执行SETSHOWPLAN_ALL的设置是在执行或运行时设置,而不是在分析时设置。需要提前执行如果 SETSHOW......
  • P6入门:项目初始化5-项目支出计划Spending Plan
    前言使用项目详细信息查看和编辑有关所选项目的详细信息,在项目创建完成后,初始化项目是一项非常重要的工作,涉及需要设置的内容包括项目名,ID,责任人,日历,预算,资金,分类码等等,在接下来的博文中,我将结合官方帮助介绍这些基本设置,希望给对P6感兴趣的人带来帮助。涉及P6 项目详情设置包括:G......
  • jmeter测试计划中的“独立运行每个线程组”Demo演示
    一:jmeter的运行顺序测试计划-->线程组其次执行顺序为:配置元件、前置处理器、定时器、取样器、后置处理器、断言、监听器当一个测试计划中有多个线程组,当多个线程组都是是执行状态时,就会用到测试计划中的“独立运行每个线程组”勾选框不勾选时的执行顺序如下:......
  • 2023年秋季个人阅读计划7
    如果强迫团队遵循一个不切实际的进度计划,不管团队遵循什么过程,那么很有可能导致彻底的失败。要建立尽责的团队,必须为其成员设定具有挑战性的目标,并要求他们制订满足这些目标的计划。团队软件过程(TSP)描述了如何建立和维护尽责的团队。针对任何企业所进行的改变都需要时间和金钱,......