洛谷P4013数字梯形问题——网络流24题
题目:https://www.luogu.org/problemnew/show/P4013
最大费用最大流裸题;
注意:在第二种情况中,底层所有点连向汇点的边容量应该为inf,因为可以有多条路径结束在同一个点。(为这个调了半天...)
代码如下:
#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
queue<int>q;
int const MAXN=,inf=1e9;
int n,m,head[MAXN],ct=,cnt,incf[MAXN],dis[MAXN],pre[MAXN],nd[MAXN],bh[][],t;
bool vis[MAXN];
struct N{
int hd,to,next,w,v;
N(int h=,int t=,int n=,int w=,int v=):hd(h),to(t),next(n),w(w),v(v) {}
}edge[MAXN<<];
void add(int x,int y,int w,int v)
{
edge[++ct]=N(x,y,head[x],w,v);head[x]=ct;
edge[++ct]=N(y,x,head[y],-w,);head[y]=ct;
}
void clr()
{
ct=;
memset(head,,sizeof head);
}
bool spfa()
{
memset(pre,,sizeof pre);
memset(dis,-,sizeof dis);
// memset(incf,3,sizeof incf);
while(q.size())q.pop();
dis[]=;vis[]=;q.push();incf[]=inf;
while(q.size())
{
int x=q.front();q.pop();
// printf("x=%d\n",x);
// cout<<x<<endl;
vis[x]=;
for(int i=head[x];i;i=edge[i].next)
{
int u=edge[i].to;
if(dis[u]<dis[x]+edge[i].w&&edge[i].v)
{
dis[u]=dis[x]+edge[i].w;
pre[u]=i;
incf[u]=min(incf[x],edge[i].v);
if(!vis[u])vis[u]=,q.push(u);
}
}
}
return pre[t];
}
void mcf()
{
long long ans=;
while(spfa())
{
ans+=incf[t]*dis[t];
// cout<<incf[t]<<" "<<dis[t]<<endl;
for(int i=pre[t];i;i=pre[edge[i].hd])
{
edge[i].v-=incf[t];
edge[i^].v+=incf[t];
}
}
printf("%lld\n",ans);
}
void cl1()
{
clr();
for(int i=;i<=n;i++)
add(,bh[][i],,);
for(int i=;i<m;i++)
for(int j=;j<n+i;j++)
{
int x=bh[i][j];
int u1=bh[i+][j],u2=bh[i+][j+];
add(x+cnt,u1,,);
add(x+cnt,u2,,);
add(x,x+cnt,nd[x],);
}
for(int i=;i<n+m;i++)
{
int x=bh[m][i];
add(x,x+cnt,nd[x],);
add(x+cnt,t,,);
}
mcf();
}
void cl2()
{
clr();
for(int i=;i<=n;i++)
add(,bh[][i],,);//!inf
for(int i=;i<m;i++)
for(int j=;j<n+i;j++)
{
int x=bh[i][j];
int u1=bh[i+][j],u2=bh[i+][j+];
add(x+cnt,u1,,);
add(x+cnt,u2,,);
add(x,x+cnt,nd[x],inf);
}
for(int i=;i<n+m;i++)
{
int x=bh[m][i];
add(x,x+cnt,nd[x],inf);
add(x+cnt,t,,inf);//inf!!!
}
mcf();
}
void cl3()
{
clr();
for(int i=;i<=n;i++)
add(,bh[][i],,);//!inf
for(int i=;i<m;i++)
for(int j=;j<n+i;j++)
{
int x=bh[i][j];
int u1=bh[i+][j],u2=bh[i+][j+];
add(x+cnt,u1,,inf);
add(x+cnt,u2,,inf);
add(x,x+cnt,nd[x],inf);
}
for(int i=;i<n+m;i++)
{
int x=bh[m][i];
add(x,x+cnt,nd[x],inf);
add(x+cnt,t,,inf);
}
mcf();
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)
for(int j=;j<n+i;j++)
{
int x;
scanf("%d",&x);
nd[++cnt]=x;
bh[i][j]=cnt;
}
t=*cnt+;
cl1();
cl2();
cl3();
return ;
}
洛谷P4013数字梯形问题——网络流24题的更多相关文章
- 洛谷 P4013 数字梯形问题
->题目链接 题解: 网络流. #include<cstdio> #include<iostream> #include<queue> #include< ...
- 洛谷P4013 数字梯形问题(费用流)
传送门 两个感受:码量感人……大佬nb…… 规则一:$m$条路径都不相交,那么每一个点只能经过一次,那么考虑拆点,把每一个点拆成$A_{i,j}$和$B_{i,j}$,然后两点之间连一条容量$1$,费 ...
- 洛谷P4013 数字梯形问题(费用流)
题意 $N$行的矩阵,第一行有$M$个元素,第$i$行有$M + i - 1$个元素 问在三个规则下怎么取使得权值最大 Sol 我只会第一问qwq.. 因为有数量的限制,考虑拆点建图,把每个点拆为$a ...
- 洛谷 P4013 数字梯形问题【最大费用最大流】
第一问:因为每个点只能经过一次,所以拆点限制流量,建(i,i',1,val[i]),然后s向第一行建(s,i,1,0),表示每个点只能出发一次,然后最后一行连向汇点(i',t,1,0),跑最大费用最大 ...
- P4013 数字梯形问题 网络流二十四题
P4013 数字梯形问题 题目描述 给定一个由 nn 行数字组成的数字梯形如下图所示. 梯形的第一行有 m 个数字.从梯形的顶部的 m 个数字开始,在每个数字处可以沿左下或右下方向移动,形成一条从梯形 ...
- P4013 数字梯形问题 网络流
题目描述 给定一个由 nn 行数字组成的数字梯形如下图所示. 梯形的第一行有 mm 个数字.从梯形的顶部的 mm 个数字开始,在每个数字处可以沿左下或右下方向移动,形成一条从梯形的顶至底的路径. 分别 ...
- Libre 6010「网络流 24 题」数字梯形 (网络流,最大费用最大流)
Libre 6010「网络流 24 题」数字梯形 (网络流,最大费用最大流) Description 给定一个由n 行数字组成的数字梯形如下图所示.梯形的第一行有m 个数字.从梯形的顶部的m 个数字开 ...
- LOJ #6010. 「网络流 24 题」数字梯形
#6010. 「网络流 24 题」数字梯形 题目描述 给定一个由 n nn 行数字组成的数字梯形如下图所示.梯形的第一行有 m mm 个数字.从梯形的顶部的 m mm 个数字开始,在每个数字处可以 ...
- 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...
随机推荐
- angular - 小结
引入样式: 导入全局 - >styles.css 导入第三方 - > 在package.json配置,然后再 npm install 安装好以后,最后再angular.json里面的sty ...
- 【Caffe代码解析】compute_image_mean
功能: 计算训练数据库的平均图像. 由于平均归一化训练图像会对结果有提升,所以Caffe里面,提供了一个可选项. 用法: compute_image_mean [FLAGS] INPUT_DB [OU ...
- Phpstorm 放大字体的快捷键是什么?
这个功能需要设置才能使用: 步骤:control+shift+A功能可以搜索对应功能 输入mouse 设置Change font size(Zoom) ...的按钮打开,然后就可以通过 ctrl+ ...
- Solaris网络基础
划分子网: 把大网缩小为若干个小网.修改子网掩码,划分多个网络. 那么如何确定子网的子网掩码和IP地址? 以上你会发现少了6个IP. Ifconfig e1000g0 down down掉网卡 ...
- JrtpLib vs2012环境下编译及使用 GotoFirstSourceWithData 方法 进不去
项目中有一项功能是接收rtp数据,接收rtp的可以用PJMedia,可以用JrtpLib.PJMedia库无法解决内外网的问题,只有用Jrtp库了. 首先说下Jrtp 的编译问题,我是在windows ...
- Can't open named pipe to host: . pipe: MySQL
今天遇到mysql连接odbc时报例如以下错误:Can't open named pipe to host: . pipe: MySQL 错误截图例如以下: 依照网上说的方法包含mysql的官方说法都 ...
- 5分钟部署filebeat + ELK 5.1.1
标题有点噱头,不过网络环境好的情况下也差不多了^_^ 1. 首先保证安装了jdk. elasticsearch, logstash, kibana,filebeat都可以通过yum安装,这里前 ...
- nvidia-docker_1.0.1-1_amd64.deb 百度云下载分享
nvidia-docker_1.0.1-1_amd64.deb 链接: https://pan.baidu.com/s/1i5pHFNZ 密码: xjui
- poj3040(双向贪心)
Allowance Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1540 Accepted: 637 Descript ...
- (转)c#(wince)中使用多线程访问winform中控件的问题
我们在做winform应用的时候,大部分情况下都会碰到使用多线程控制界面上控件信息的问题.然而我们并不能用传统方法来做这个问题,下面我将详细的介绍. 首先来看传统方法: public partial ...