洛谷题目传送门!

题目描述

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

在前期市场调查和站址勘测之后,公司得到了一共 N 个可以作为通讯信号中转站的地址,而由于这些地址的地理位置差异,在不同的地方建造通讯中转站需要投入的成本也是不一样的,所幸在前期调查之后这些都是已知数据:建立第 i个通讯中转站需要的成本为PiP_iP

另外公司调查得出了所有期望中的用户群,一共 M 个。关于第 i 个用户群的信息概括为AiA_iABiB_iBCiC_iCCiC_iCAiA_iABiB_iB

THU 集团的 CS&T 公司可以有选择的建立一些中转站(投入成本),为一些用户提供服务并获得收益(获益之和)。那么如何选择最终建立的中转站才能让公司的净获利最大呢?(净获利 = 获益之和 – 投入成本之和)

输入输出格式

  1. 输入格式:

输入文件中第一行有两个正整数 N 和 M 。

第二行中有 N 个整数描述每一个通讯中转站的建立成本,依次为P1,P2,…,PNP_1 , P_2 , …,P_NP

以下 M 行,第(i + 2)行的三个数Ai,BiA_i , B_iACiC_iC

所有变量的含义可以参见题目描述。


  1. 输出格式:

你的程序只要向输出文件输出一个整数,表示公司可以得到的最大净获利。

输入输出样例

输入样例#1: 复制

  1. 5 5
  2. 1 2 3 4 5
  3. 1 2 3
  4. 2 3 4
  5. 1 3 3
  6. 1 4 2
  7. 4 5 3
输出样例#1: 复制

  1. 4

说明

样例:选择建立 1、2、3 号中转站,则需要投入成本 6,获利为 10,因此得到最大收益 4。

很明显,直接用网络流模板。

首先考虑如何建模型:

                                                                             

  1. 先建立超级源点(废话), 然后连向每一个中转站,流量为成本 cost 然后再从中转站连向使用它的用户,流量为INF (选择不影响价格,因此流量无限大)。最后从用户流向汇点,
    流量为获利gain
    接着,算出所有用户gain的总值,减掉最小割(最大流)即可。
  2. So Why
  3. 首先先看我们需要计算的是什么: 总获利 - 总成本。
    对于亏本用户,其gain 小于 cost 从其流出的流量肯定 <= gain。因此我们将这部分剪掉,相当于收益为0.
    对于赚钱用户,其gain 大于 cost 从其流出的流量肯定 <= cost。因此我们将这部分剪掉,相当于剪掉了cost,即为实际利润。
  4. 因此,建图完成。当前弧优化(不能忘,否则T掉)+ Dicnic 板子。 (当然,用SPFA的最小费用最大流版本也能跑,
    设单位费用为1即可,但是速度好像更慢,内存更大)。那为什么还用,雾。
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. #define N 500010
  4. #define ll long long
  5. #define INF (~0u>>1)
  6. #define isdigit(c) ((c)>='0'&&(c)<='9')
  7.  
  8. // https://www.luogu.com.cn/problem/P4174
  9.  
  10. inline int read(){
  11. ll x = , s = ;
  12. char c = getchar();
  13. while(!isdigit(c)){
  14. if(c == '-')s = -;
  15. c = getchar();
  16. }
  17. while(isdigit(c)){
  18. x = x * + c - '';
  19. c = getchar();
  20. }
  21. return x * s;
  22. }
  23.  
  24. struct node{
  25. int u, v, w;
  26. int next = -;
  27. }t[N];
  28. int f[N];
  29. int ht, s;
  30. int deth[N], cur[N];
  31. int n, m;
  32.  
  33. int bian = -;//全部从-1开始
  34. void addedge(ll u, ll v,ll w){
  35. bian++;
  36. t[bian].u = u;
  37. t[bian].v = v;
  38. t[bian].w = w;
  39. t[bian].next = f[u];
  40. f[u] = bian;
  41. return ;
  42. }
  43.  
  44. inline void add(ll u, ll v,ll w){ //注意要加反边。这里就如此写了
  45. addedge(u, v, w);
  46. addedge(v, u, );
  47. return ;
  48. }
  49. queue <int> q;
  50. bool bfs(int s, int ht){
  51. memset(deth, , sizeof(deth));
  52. while(!q.empty())q.pop();//进行初始化
  53. q.push(s);
  54. deth[s] = ;//起点记得设为-1
  55. while(!q.empty()){
  56. int now = q.front();q.pop();
  57. for(int i = f[now]; ~i; i = t[i].next){
  58. int v = t[i].v, u = t[i].u, w = t[i].w;
  59. if(!deth[v] && w > ){
  60. deth[v] = deth[u] + ; // 分层操作
  61. q.push(v);
  62. }
  63. }
  64. }
  65. return deth[ht] != ;
  66. }
  67.  
  68. ll dfs(int now,int dist){
  69. if(now == ht)return dist;
  70. for(int& i = cur[now]; ~i; i = t[i].next){ // 记得当前弧优化
  71. int w = t[i].w, v = t[i].v, u = t[i].u;
  72. if(deth[v] == deth[u] + && w){
  73. int di = dfs(v, min(dist, w));
  74. if(di > ){
  75. t[i].w -= di;
  76. t[i^].w += di;
  77. return di;
  78. }
  79. }
  80. }
  81. return ;
  82. }
  83. ll Dicnic(){ // 经典Dicnic 操作,就是板子
  84. ll ans = ;
  85. while(bfs(s, ht)){
  86. memcpy(cur, f, sizeof(cur));
  87. while(ll temp = dfs(s,INF))
  88. ans += temp;
  89. }
  90. return ans;
  91. }
  92.  
  93. int main(){
  94. // freopen("P4174_9.in", "r", stdin);
  95. memset(f, -, sizeof(f));
  96. n = read(), m = read();
  97. for(int i = ;i <= n; i++){
  98. int temp = read();
  99. add(, i, temp); // 从源点连向中转站
  100. }
  101. ll ans = ;
  102. int to1, to2, temp;
  103. for(int i = ;i <= m; i++){
  104. int to1 = read(), to2 = read(), temp = read();
  105. add(to1, i + n, INF);
  106. add(to2, i + n, INF);
  107. add(i + n, + m + n, temp);//从用户连向汇点
  108. ans += temp;
  109. }
  110. s = , ht = n + m + ;
  111. ans -= Dicnic();//减掉届不到的用户和届到的中转站
  112. printf("%lld\n", ans);
  113. return ;
  114. }
  1.  
  1.  

典型的脑子题,动手简单动脑难

NOI2006 最大获利 洛谷P4174的更多相关文章

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

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

  2. 洛谷 P4174 [NOI2006]最大获利 解题报告

    P4174 [NOI2006]最大获利 题目描述 新的技术正冲击着手机通讯市场,对于各大运营商来说,这既是机遇,更是挑战.THU 集团旗下的 CS&T 通讯公司在新一代通讯技术血战的前夜,需要 ...

  3. 洛谷P4174 [NOI2006]最大获利(最大流)

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

  4. [洛谷P4174][NOI2006]最大获利

    题目大意:同Petya and Graph,数据范围改成$n\leqslant5\times10^3,m\leqslant5\times10^4$ 题解:同上 卡点:无 C++ Code: #incl ...

  5. P4174 [NOI2006]最大获利(网络流)

    P4174 [NOI2006]最大获利 还是最大权闭合子图的题 对于每个中转站$k$:$link(k,T,P_k)$ 对于每个用户$i$.中转站$A_i,B_i$.贡献$C_i$ $link(S,i, ...

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

    P4174 [NOI2006]最大获利 (最大权闭合子图) 题目链接 题意 建\(i\)站台需要\(p_i\)的花费,当\(A_i,B_i\)都建立时获得\(C_i\)的利润,求最大的利润 思路 最大 ...

  7. 洛谷 P2949 [USACO09OPEN]工作调度Work Scheduling 题解

    P2949 [USACO09OPEN]工作调度Work Scheduling 题目描述 Farmer John has so very many jobs to do! In order to run ...

  8. [NOI2006] 最大获利

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

  9. 洛谷1640 bzoj1854游戏 匈牙利就是又短又快

    bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...

随机推荐

  1. python——append后的列表为什么打印出来为空

    关于python 列表append的用法: list = [] list = list.append("c") print(list) >>>None 正确写法应 ...

  2. Ajax各参数介绍及使用

    Ajax各参数介绍及使用 1. url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2. type: 要求为String类型的参数,请求方式(post或get)默认为get. ...

  3. 题目分享D 二代目

    题意:给定一个T条边的无向图,求S到E恰好经过N条边的最短路径 T≤100 N≤1000000 分析:(据说好像假期学长讲过) 首先很容易想到的是dp[i][j][k]表示从i到j经过k条边的最短路径 ...

  4. Java——多线程之对象及变量的并发访问

    Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...

  5. mui指南

    转自https://www.cnblogs.com/koleyang/p/5146623.html http://dev.dcloud.net.cn/mui/ui/index.html#mask ht ...

  6. Mysql常用sql语句(八)- where 条件查询

    测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html 前言 ...

  7. 你的团队需要一个正确的程序集(dll)管理姿势

    很多团队经历时间的积淀之后,都会有很多的可重用的公共技术组件.大部分的团队都会把这些公共组件生成程序集(dll)后,放到GIT或SVN的一个公共目录里面,以供各个项目中使用.起初在项目很少又或者是公共 ...

  8. 【HDU4990】递推式

    题目大意:给定序列 1, 2, 5, 10, 21, 42, 85, 170, 341 …… 求第n项 模 m的结果 递推式 f[i]  = f[i - 2] + 2 ^ (i - 1); 方法一:  ...

  9. Redis数据类型简介(十分钟快速学习Redis)

    如何在ubuntu18.04上安装和保护redis 如何连接到Redis数据库 如何管理Redis数据库和Keys 如何在Redis中管理副本和客户端 如何在Redis中管理字符串 如何在Redis中 ...

  10. Analysis分析器

    一.Analysis简介 场景执行过程中,loadrunner收集执行过程中的数据,存储在扩展名为.lrr的文件中,Analysis分析器打开这个文件,对文件信息进行处理,并生成图和报告. 数据分析不 ...