CF_863_F(Netflow)
题目大意:给出一个数组的大小(n<=50
),以及每个位置填数的范围限制(若无限制,即为1-n
),最后求填出数组的最小花费,定义总花费为数组中每个数出现次数的平方和。(sum_cnt[i]^2 (1<=i<=n)
)。
题解:费用流,要不是最近在学,我都不敢信网络流这么强大,想清楚怎么转化和建边之后,实现没有什么细节,关键是转化,如果第一次遇见是挺吃脑子的。下面来给出建边:将每个数和S
连n
条边(容量1
,花费为2*j-1
, j
为这是这个数的第几条边),然后每个数和可以放这个数的位置连边(容量1
, 费用0
),最后每个位置和T
连边(容量费用同上)。下面来解释一下建边的原因,因为题目要求的花费是出现次数的平方,那我们考虑其中一个数,怎么让花费是次数平方呢?最直接的想法就是连n
条边(容量i
,费用i
, 1<=i<=n
), 这样i*i
(费用流的所谓的费用是单位费用,即单位流量的费用),表示i
这个数用i
次的费用,是不是很完美?可是,我们想想费用流是怎么跑的,它有个最短路,跑的是花费,那么问题来了,假设我们要当前这个数使用两次,那么讲道理应该跑e(2,2)
,这条边,可是其实两次是怎么跑的?是先跑了e(1,1)
,走一个流量,再从e(2,2)
走一个流量,这样一来,花费是1+2=3 != 4
,显然就错误了,那么问题来了,发现走几次其实就是用了几条这个数的边,那么有没有一个前缀和能让前i
条边的边权和为i^2
?答案就是1,3,5,7......
这个等差数列的第i
次前缀和就是i^2
。那么最关键的建边解释完了,剩下的建边没什么好说的,容量1
是因为每个位置最后只有一个数,而每个位置对于整个数列只贡献一个位置,花费0
是因为,从S
到所有数的连边泡完就算完了花费,后面自然为0
。
PS:不要说什么LLF,SLF
的SPFA
,就是势叠加的Dij
直接莽(Dij
记得加vis
,奇快无比,因为T过,所以懂得,那次T得太惨了)。是真的难受,没看题解不知道怎么建边,大概猜到了会是网络流,因为画了画感觉可以用图做(都是美食节那题迫害的,至今未动)。
时限:46ms / 3S
#pragma comment(linkerr, "/STACK: 1024000000,1024000000")
#include <bits/stdc++.h>
#define pb push_back
#define mp make_pair
#define eb emplace_back
#define em emplace
#define pii pair<int,int>
#define de(x) cout << #x << " = " << x << endl
#define clr(a,b) memset(a,b,sizeof(a))
#define INF (0x3f3f3f3f)
#define LINF ((long long)(0x3f3f3f3f3f3f3f3f))
#define F first
#define S second
using namespace std;
const int M = 2e5 + 15;
const int N = 55;
int mxflw = 0, mncst = 0;
pii ans;
int S, T;
int n, q;
pii a[N];
struct Edge
{
int v, f, w, nxt;
};
Edge e[M<<1];
int h[N*4], ect;
int g[N*4], dis[N*4];
int pv[N*4], pe[M<<1];
bool vis[N*4];
void init()
{
clr(h,-1);
ect = 0;
}
void _add( int u, int v, int f, int w )
{
e[ect].v = v, e[ect].f = f, e[ect].w = w, e[ect].nxt = h[u], h[u] = ect++;
e[ect].v = u, e[ect].f = 0, e[ect].w =-w, e[ect].nxt = h[v], h[v] = ect++;
}
pii mfmc( int s, int t )
{
while ( 1 )
{
priority_queue<pii> q;
clr(vis,false);
for ( int i = s; i <= t; i ++ )
dis[i] = INF; dis[s] = 0;
q.push( {0,s} );
while ( !q.empty() )
{
pii nw = q.top(); q.pop();
int u = nw.S;
if ( vis[u] ) continue;
vis[u] = true;
for ( int i = h[u]; i+1; i = e[i].nxt )
{
int v = e[i].v;
int cst = e[i].w + g[u] - g[v];
if ( e[i].f > 0 && dis[v] > dis[u] + cst )
{
dis[v] = dis[u] + cst;
pe[v] = i, pv[v] = u;
q.push( { -dis[v], v } );
}
}
}
if ( dis[t] == INF ) break;
for ( int i = s; i <= t; i ++ )
g[i] += dis[i];
int d = INF;
for ( int i = t; i != s; i = pv[i] )
d = min( d, e[ pe[i] ].f );
for ( int i = t; i != s; i = pv[i] )
{
int id = pe[i];
e[id].f -= d, e[id^1].f += d;
}
mxflw += d, mncst += d*g[t];
}
return { mxflw, mncst };
}
int main()
{
init();
scanf("%d%d", &n, &q);
for ( int i = 1; i <= n; i ++ )
a[i].F = 1, a[i].S = n;
while ( q -- )
{
int p, l, r, v;
scanf("%d%d%d%d", &p, &l, &r, &v);
for ( int i = l; i <= r; i ++ )
if ( p == 1 ) a[i].F = max( a[i].F, v );
else a[i].S = min( a[i].S, v );
}
S = 0, T = 2*n + 1;
for ( int i = 1; i <= n; i ++ )
{
for ( int j = 1; j <= n; j ++ )
_add( S, i, 1, 2*j-1 ); //S -> num
_add( i+n, T, 1, 0 ); //pos -> T
}
for ( int i = 1; i <= n; i ++ )
{
for ( int j = a[i].F; j <= a[i].S; j ++ )
_add( j, i+n, 1, 0 ); //num -> pos
}
ans = mfmc( S, T );
printf("%d\n", ans.F == n ? ans.S : -1);
return 0;
}
CF_863_F(Netflow)的更多相关文章
- GitHub NetFlow
https://github.com/search?l=Java&p=1&q=netflow&ref=searchresults&type=Repositories&a ...
- NetFlow
供应商 支持的流 设备列表 Cisco NetFlow Cisco - 800.1700.2600.1800.2800.3800.4500.6500.7200.7300.7500.7600.10000 ...
- 【流量】netflow 基础知识
摘要 记录下关于netflow的基础知识以及应用,现状 是什么 一种数据交换方式,NetFlow流量统计数据包括数据流时戳 源IP地址和目的IP地址 源端口号和目的端口号 输入接口号和输出接口号 下一 ...
- NetFlow学习笔记
NetFlow学习笔记 标签: netflow 由于工作需要,对NetFlow做了一些学习和调研,并总结成文档以供学习分享. 背景:随着系统的升级与漏洞的修补,入侵主机进而进行破坏的病毒攻击方式在攻击 ...
- 基于Spark和SparkSQL的NetFlow流量的初步分析——scala语言
基于Spark和SparkSQL的NetFlow流量的初步分析--scala语言 标签: NetFlow Spark SparkSQL 本文主要是介绍如何使用Spark做一些简单的NetFlow数据的 ...
- Openvswitch手册(3): sFlow, netFlow
这一节,我们重点看sFlow 采样流sFlow(Sampled Flow)是一种基于报文采样的网络流量监控技术,主要用于对网络流量进行统计分析. sFlow系统包含一个嵌入在设备中的sFlow Age ...
- [转]Comparing sFlow and NetFlow in a vSwitch
As virtualization shifts the network edge from top of rack switches to software virtual switches run ...
- [转]Rapidly detecting large flows, sFlow vs. NetFlow/IPFIX
Figure 1: Low latency software defined networking control loop The articles SDN and delay and Delay ...
- Cisco ISR4400 Netflow 配置模板
flow exporter NAME destination 145.0.1.200 transport udp 9991 export-protocol netflow-v5 flow monito ...
随机推荐
- 【BZOJ3011】[Usaco2012 Dec]Running Away From the Barn 可并堆
[BZOJ3011][Usaco2012 Dec]Running Away From the Barn Description It's milking time at Farmer John's f ...
- android异常:Can not perform this action after onSaveInstanc
extends:http://zhiweiofli.iteye.com/blog/1539467 本人某个android项目开发阶段一直运行良好,直到上线前夕,在某款跑着android 4.03系统的 ...
- 微信小程序 --- 缓存数据
保存数据 / 读取数据 / 删除数据 / 数据异步操作 每一个微信小程序都可以有自己的本地缓存,可以通过wx.setStorage( wx.setStorageSync) ,wx.getS ...
- debug error 错误日志的调试模式
https://docs.nginx.com/nginx/admin-guide/monitoring/logging/ error_log logs/error.log warn; In this ...
- Rancher OS
Rancher OS 是生产规模中运行 Docker 最小,最简单的方式.RancherOS 的所有东西都作为 Docker 管理的容器.这些系统服务包括 udev 和 rsyslog.Rancher ...
- 服务器和客户端的交互方式(Socket,http协议)和各自特点适用范围
1 数据传输方式 1.1 Socket传输的定义和其特点 所谓socket通常也称作"套接字",实现服务器和客户端之间的物理连接,并进行数据传输,主要有UDP和TCP两个协议.S ...
- Lightoj 1003 - Drunk(拓扑排序判断是否有环 Map离散化)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1003 题意是有m个关系格式是a b:表示想要和b必须喝a,问一个人是否喝醉就看一个人是 ...
- 当Web访问性能出现问题,如何深探?
对运维或开发工程师来说,遇到访问性能问题时,最先需要定位的是问题出现在哪个环节,是网络的问题,服务端的问题,还是客户端的问题? 往往技术人员喜欢把精力放在保障后端服务的可用性方面,而对前端界面是否能正 ...
- django-models的get与filter
为了说明它们两者的区别定义2个models class Student(models.Model):name = models.CharField('姓名', max_length=20, defau ...
- 001-ant design安装及快速入门【基于纯antd的基本项目搭建】
一.安装使用 1.1.安装 推荐使用 npm 或 yarn 的方式进行开发 npm install antd --save yarn add antd 1.2.浏览器引入 在浏览器中使用 script ...