题目: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题的更多相关文章

  1. 洛谷 P4013 数字梯形问题

    ->题目链接 题解: 网络流. #include<cstdio> #include<iostream> #include<queue> #include< ...

  2. 洛谷P4013 数字梯形问题(费用流)

    传送门 两个感受:码量感人……大佬nb…… 规则一:$m$条路径都不相交,那么每一个点只能经过一次,那么考虑拆点,把每一个点拆成$A_{i,j}$和$B_{i,j}$,然后两点之间连一条容量$1$,费 ...

  3. 洛谷P4013 数字梯形问题(费用流)

    题意 $N$行的矩阵,第一行有$M$个元素,第$i$行有$M + i - 1$个元素 问在三个规则下怎么取使得权值最大 Sol 我只会第一问qwq.. 因为有数量的限制,考虑拆点建图,把每个点拆为$a ...

  4. 洛谷 P4013 数字梯形问题【最大费用最大流】

    第一问:因为每个点只能经过一次,所以拆点限制流量,建(i,i',1,val[i]),然后s向第一行建(s,i,1,0),表示每个点只能出发一次,然后最后一行连向汇点(i',t,1,0),跑最大费用最大 ...

  5. P4013 数字梯形问题 网络流二十四题

    P4013 数字梯形问题 题目描述 给定一个由 nn 行数字组成的数字梯形如下图所示. 梯形的第一行有 m 个数字.从梯形的顶部的 m 个数字开始,在每个数字处可以沿左下或右下方向移动,形成一条从梯形 ...

  6. P4013 数字梯形问题 网络流

    题目描述 给定一个由 nn 行数字组成的数字梯形如下图所示. 梯形的第一行有 mm 个数字.从梯形的顶部的 mm 个数字开始,在每个数字处可以沿左下或右下方向移动,形成一条从梯形的顶至底的路径. 分别 ...

  7. Libre 6010「网络流 24 题」数字梯形 (网络流,最大费用最大流)

    Libre 6010「网络流 24 题」数字梯形 (网络流,最大费用最大流) Description 给定一个由n 行数字组成的数字梯形如下图所示.梯形的第一行有m 个数字.从梯形的顶部的m 个数字开 ...

  8. LOJ #6010. 「网络流 24 题」数字梯形

    #6010. 「网络流 24 题」数字梯形   题目描述 给定一个由 n nn 行数字组成的数字梯形如下图所示.梯形的第一行有 m mm 个数字.从梯形的顶部的 m mm 个数字开始,在每个数字处可以 ...

  9. 网络流24题 第三题 - CodeVS1904 洛谷2764 最小路径覆盖问题 有向无环图最小路径覆盖 最大流 二分图匹配 匈牙利算法

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - CodeVS1904 题目传送门 - 洛谷2764 题意概括 给出一个有向无环图,现在请你求一些路径,这些路径 ...

随机推荐

  1. angular - 小结

    引入样式: 导入全局 - >styles.css 导入第三方 - > 在package.json配置,然后再 npm install 安装好以后,最后再angular.json里面的sty ...

  2. 【Caffe代码解析】compute_image_mean

    功能: 计算训练数据库的平均图像. 由于平均归一化训练图像会对结果有提升,所以Caffe里面,提供了一个可选项. 用法: compute_image_mean [FLAGS] INPUT_DB [OU ...

  3. Phpstorm 放大字体的快捷键是什么?

      这个功能需要设置才能使用: 步骤:control+shift+A功能可以搜索对应功能 输入mouse 设置Change font size(Zoom) ...的按钮打开,然后就可以通过 ctrl+ ...

  4. Solaris网络基础

      划分子网: 把大网缩小为若干个小网.修改子网掩码,划分多个网络. 那么如何确定子网的子网掩码和IP地址? 以上你会发现少了6个IP.   Ifconfig e1000g0 down down掉网卡 ...

  5. JrtpLib vs2012环境下编译及使用 GotoFirstSourceWithData 方法 进不去

    项目中有一项功能是接收rtp数据,接收rtp的可以用PJMedia,可以用JrtpLib.PJMedia库无法解决内外网的问题,只有用Jrtp库了. 首先说下Jrtp 的编译问题,我是在windows ...

  6. Can&#39;t open named pipe to host: . pipe: MySQL

    今天遇到mysql连接odbc时报例如以下错误:Can't open named pipe to host: . pipe: MySQL 错误截图例如以下: 依照网上说的方法包含mysql的官方说法都 ...

  7. 5分钟部署filebeat + ELK 5.1.1

    标题有点噱头,不过网络环境好的情况下也差不多了^_^   1. 首先保证安装了jdk.   elasticsearch, logstash, kibana,filebeat都可以通过yum安装,这里前 ...

  8. nvidia-docker_1.0.1-1_amd64.deb 百度云下载分享

    nvidia-docker_1.0.1-1_amd64.deb 链接: https://pan.baidu.com/s/1i5pHFNZ 密码: xjui

  9. poj3040(双向贪心)

    Allowance Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 1540   Accepted: 637 Descript ...

  10. (转)c#(wince)中使用多线程访问winform中控件的问题

    我们在做winform应用的时候,大部分情况下都会碰到使用多线程控制界面上控件信息的问题.然而我们并不能用传统方法来做这个问题,下面我将详细的介绍. 首先来看传统方法:  public partial ...