P4174 [NOI2006]最大获利 (最大权闭合子图)

题目链接

题意

建\(i\)站台需要\(p_i\)的花费,当\(A_i,B_i\)都建立时获得\(C_i\)的利润,求最大的利润

思路

最大权闭合子图模板题

参考论文

将所有站台与S连接,边权值为\(P_i\),将第\(i\)个利润与\(T\)连接,边权为\(C_i\),再与\(A_i,B_i\)连接,边权为\(inf\),跑网络流,最小割 = 建立站台的花费 + 不要的利润 ,Ans = 所有的利润 - (建立站台的花费 + 不要的利润) = 所有的利润 - 最小割

最小割 = 最大流

样例图

代码

#include <bits/stdc++.h>
using namespace std;
const int inf = 1<<30;
const int N = 55500;
const int M = 502020;
int f[N], w[M], nxt[M], to[M], h[N];
int num;
void add(int x,int y,int z)
{
to[++num] = y;
w[num] = z;
nxt[num] = f[x];
f[x] = num;
to[++num] = x;
w[num] = 0;
nxt[num] = f[y];
f[y] = num;
}
int bfs(int s,int t)
{
memset(h,0,sizeof(h));
h[s] = 1;
queue <int > q;
q.push(s);
while (!q.empty())
{
int x = q.front();
q.pop();
for (int i = f[x]; i; i = nxt[i])
{
int y = to[i];
if (!h[y] && w[i])
{
h[y] = h[x] + 1;
q.push(y); }
}
}
if (!h[t] ) return 0;
else return 1;
}
int dfs(int x,int t,int flow)
{
if(x==t) return flow;
int fl=0;
for(int i=f[x]; i && flow ;i=nxt[i])
{
if(h[to[i]]==h[x]+1&&w[i])
{
int mi=dfs(to[i],t,min(w[i],flow));
w[i]-=mi; w[i^1]+=mi; fl+=mi; flow-=mi;
}
}
if(!fl) h[x]=-1;
return fl;
}
long long dinic(int s,int t)
{
long long ret = 0;
while (bfs(s,t)) ret += dfs(s,t,inf);
return ret;
}
int main()
{
ios::sync_with_stdio(false);
int n,m;
cin >> n >> m;
num = 1;
for (int i = 1; i <= n; i++)
{
int x;
cin >> x;
add(0,i,x);
}
long long tot = 0;
for (int i = 1; i <= m; i++)
{
int x, y, z;
cin >> x >> y >> z;
tot += z;
add(x,i+n,inf);
add(y,i+n,inf);
add(i+n,m+n+1,z);
}
cout << tot - dinic(0,n+m+1) << endl;
}

P4174 [NOI2006]最大获利 (最大权闭合子图)的更多相关文章

  1. BZOJ1497[NOI2006]最大获利——最大权闭合子图

    题目描述 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机遇,更是挑战.THU集团旗下的CS&T通讯公司在新一代通讯技术血战的前夜,需要做太多的准备工作,仅就站址选择一项,就需要完成 ...

  2. 【BZOJ】1497: [NOI2006]最大获利 最大权闭合子图或最小割

    [题意]给定n个点,点权为pi.m条边,边权为ci.选择一个点集的收益是在[点集中的边权和]-[点集点权和],求最大获利.n<=5000,m<=50000,0<=ci,pi<= ...

  3. bzoj1497 [NOI2006]最大获利 最大权闭合子图

    链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1497 思路 最大权闭合子图的裸题 一开始知道是这个最大权闭合子图(虽然我不知道名字),但是我 ...

  4. COGS28 [NOI2006] 最大获利[最大权闭合子图]

    [NOI2006] 最大获利 ★★★☆   输入文件:profit.in   输出文件:profit.out   简单对比时间限制:2 s   内存限制:512 MB [问题描述] 新的技术正冲击着手 ...

  5. bzoj1497 最大获利(最大权闭合子图)

    题目链接 思路 对于每个中转站向\(T\)连一条权值为建这个中转站代价的边.割掉这条边表示会建这个中转站. 对于每个人向他的两个中转站连一条权值为\(INF\)的边.然后从\(S\)向这个人连一条权值 ...

  6. BZOJ 1497 最大获利(最大权闭合子图)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1497 思路:由题意可以得知,每个顾客都依赖2个中转站,那么让中转站连有向边到汇点,流量为它的建设费用 ...

  7. 洛谷 P4174 [NOI2006]最大获利 && 洛谷 P2762 太空飞行计划问题 (最大权闭合子图 && 最小割输出任意一组方案)

    https://www.luogu.org/problemnew/show/P4174 最大权闭合子图的模板 每个通讯站建一个点,点权为-Pi:每个用户建一个点,点权为Ci,分别向Ai和Bi对应的点连 ...

  8. BZOJ 1497: [NOI2006]最大获利(最大权闭合子图)

    1497: [NOI2006]最大获利 Time Limit: 5 Sec  Memory Limit: 64 MB Description 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机 ...

  9. luogu p4174 最大获利(最大权闭合子图)

    luogu p4174 最大获利(最大权闭合子图) 给定n个点,m条边,每条边有一个贡献,每个点有一个代价.选择一条边,会付出边所连两个点的代价,问最大代价. 我们换个建图方式:把图G中的边\(e_i ...

随机推荐

  1. Java江湖之设计模式

    Java江湖之设计模式 ps:最近在学习设计模式,感觉这个是个装逼神器呀,就跟武功一样.     某日,senior同学看见rookie同学在练功.     问,"你练得什么武功?" ...

  2. C#录制视频

    这是一个使用C#语言制作的录制框架,支持录制桌面,多屏,声音,摄像头,某个应用程序的界面 1.安装 使用此框架需要安装扩展包Kogel.Record,可以Nuget上搜索 或者使用Nuget命令 In ...

  3. spring-boot第一章:快速开始

    快速开始 创建pom.xml文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns= ...

  4. Lua表(table)的个人总结

    1.表的简介和构造 table是个很强大且神奇的东西,又可以作为数组和字典,又可以当作对象,设置module.它是由数组和哈希表结合的实现的.他的key可以是除nil以外任意类型的值,key为整数时, ...

  5. swiper如何禁止用户滑动

    禁止用户滑动,只需要在最外层添加class  “swiper-no-swiping” <div class="swiper-container swiper-no-swiping&qu ...

  6. cogs 886. [USACO 4.2] 完美的牛栏 二分图 匈牙利算法

    886. [USACO 4.2] 完美的牛栏 ★★☆   输入文件:stall4.in   输出文件:stall4.out   简单对比时间限制:1 s   内存限制:128 MB USACO/sta ...

  7. gcd竞赛模板

    int gcd(int a,int b) { ) return a; return gcd(b,a%b); }

  8. hdu - 4990

    Read the program below carefully then answer the question.    #pragma comment(linker, "/STACK:1 ...

  9. 洛谷 p3834 主席树

    题目链接:https://www.luogu.org/problem/P3834 主席树求静态区间第k小 #include<iostream> #include<cstdio> ...

  10. mysql 注入问题

    1.实质 MySql语句是用户自行拼接的字符串 2.例子 import pymysql # 获取用户输入信息 username = input("请输入用户名:") pwd = i ...