/*
poj3422 Kaka's Matrix Travels
不知道 k次 dp做为什么不对???
看了大牛的代码,才知道还可以这样做!
开始没有理解将a 和 a‘ 之间建立怎样的两条边,导致程序一直陷入死循环,真心花了好长时间,快崩溃了。无语.....
题意:有个方阵,每个格子里都有一个非负数,从左上角走到右下角,每次走一步,只能往右或往下走,经过的数字拿走
每次都找可以拿到数字和最大的路径走,走k次,求最大和 这是 最大费用最大流 问题 每次spfa都找的是一条和最大的路径 s--到左上角的边流量是K限制增广次数 求最大费用最大流只需要把费用换成相反数,用最小费用最大流求解即可 构图过程:
每个点拆分成两个 a a' 之间建两条边(当然还要建退边),分别是 (费用为该点相反数,流量为1) (费用为0,流量为k-1)
路过这点时,可以通过前边那条边拿到数字,
以后再从这儿过,就没有数字可拿了,走的就是第二条边 然后是 没点向 右和下 建一条边 费用0,流量k
*/
#include<iostream>
#include<queue>
#include<cstring>
#include<cstdio>
#define N 50000
#define M 5005
#define Max 0x3f3f3f3f
using namespace std;
class EDGE
{
public:
int u, v, c, f;
int next;
};
queue<int>q;
EDGE edge[N];
int cap[][], n, k;
int pre[N], first[N];
int dist[M], vis[M];
int edgeN;
int s, t;
int maxFlow; int spfa()
{
memset(dist, 0x3f, sizeof(dist));
memset(vis, , sizeof(vis));
memset(pre, -, sizeof(pre));
dist[s]=;
q.push(s);
vis[s]=;
while(!q.empty())
{
int u=q.front();
q.pop();
vis[u]=;
for(int e=first[u]; e!=-; e=edge[e].next)
{
int v=edge[e].v;
if(dist[v]>dist[u] + edge[e].c && edge[e].f>)
{
dist[v]=dist[u] + edge[e].c;
pre[v]=e;
if(!vis[v])
{
vis[v]=;
q.push(v);
}
}
}
}
if(dist[t]==Max)
return ;
return ;
} void updateFlow()
{
int minF=Max;
for(int e=pre[t]; e!=-; e=pre[edge[e].u])
if(minF>edge[e].f)
minF=edge[e].f;
for(int e=pre[t]; e!=-; e=pre[edge[e].u])
{
edge[e].f-=minF;
edge[e^].f+=minF;
maxFlow+=minF*edge[e].c;
}
} void adde(int u, int v, int c, int f)
{
edge[edgeN].u=u; edge[edgeN].v=v;
edge[edgeN].c=c; edge[edgeN].f=f;
edge[edgeN].next=first[u]; first[u]=edgeN++; edge[edgeN].u=v; edge[edgeN].v=u;
edge[edgeN].c=-c; edge[edgeN].f=;
edge[edgeN].next=first[v]; first[v]=edgeN++;
} int main()
{
int i, j;
while(scanf("%d%d", &n, &k)!=EOF)
{
maxFlow=;
edgeN=;
memset(first, -, sizeof(first));
s=; t=n*n*+;
for(i=; i<=n; ++i)
for(j=; j<=n; ++j)
scanf("%d", &cap[i][j]);
adde(s, , , k);
for(i=; i<=n; ++i)
for(j=; j<=n; ++j)//n*n个节点,拆点之后变成2*n*n个节点
{
int nb=(i-)*n+j;
adde(*nb-, *nb, -cap[i][j], );//注意:a到a`是建立两条边,但是两条边的费用和容量不一样
adde(*nb-, *nb, , k-);
if(j<n)//向右建图
adde(*nb, *(nb+)-, , k);
if(i<n)//向下建图
adde(*nb, *(nb+n)-, , k);
}
adde(n*n*, t, , k); while(spfa())//建好图之后,直接调用最小费用最大流模板就好了
updateFlow();
printf("%d\n", -maxFlow);
}
return ;
}

poj3422 Kaka's Matrix Travels(最小费用最大流问题)的更多相关文章

  1. POJ3422 Kaka's Matrix Travels 【费用流】*

    POJ3422 Kaka's Matrix Travels Description On an N × N chessboard with a non-negative number in each ...

  2. [poj] 3422 Kaka's Matrix Travels || 最小费用最大流

    原题 给一个N*N的方阵,从[1,1]到[n,n]走K次,走过每个方格加上上面的数,然后这个格上面的数变为0.求可取得的最大的值. 要求最大值,所以把边权全为负跑最小费用即可.因为只有第一次经过该点的 ...

  3. POJ3422 Kaka's Matrix Travels[费用流]

    Kaka's Matrix Travels Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9522   Accepted:  ...

  4. POJ 3422 Kaka's Matrix Travels(费用流)

    Kaka's Matrix Travels Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6792   Accepted:  ...

  5. POJ3422 Kaka's Matrix Travels

    描述 On an N × N chessboard with a non-negative number in each grid, Kaka starts his matrix travels wi ...

  6. POJ 3422 Kaka&#39;s Matrix Travels(费用流)

    POJ 3422 Kaka's Matrix Travels 题目链接 题意:一个矩阵.从左上角往右下角走k趟,每次走过数字就变成0,而且获得这个数字,要求走完之后,所获得数字之和最大 思路:有点类似 ...

  7. POJ 3422 Kaka's Matrix Travels

    Kaka's Matrix Travels Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9567   Accepted:  ...

  8. POJ训练计划3422_Kaka&#39;s Matrix Travels(网络流/费用流)

    解题报告 题目传送门 题意: 从n×n的矩阵的左上角走到右下角,每次仅仅能向右和向下走,走到一个格子上加上格子的数,能够走k次.问最大的和是多少. 思路: 建图:每一个格子掰成两个点,分别叫" ...

  9. POJ 3422 Kaka's Matrix Travels 【最小费用最大流】

    题意: 卡卡有一个矩阵,从左上角走到右下角,卡卡每次只能向右或者向下.矩阵里边都是不超过1000的正整数,卡卡走过的元素会变成0,问卡卡可以走k次,问卡卡最多能积累多少和. 思路: 最小费用最大流的题 ...

随机推荐

  1. Minimum configuration for openldap to proxy multiple AD into a single search base

    [root@localhost ~]# cd /etc/openldap[root@localhost openldap]# cat slapd.confloglevel 0x900include / ...

  2. docker pull certification error

    export DOMAIN_NAME=<my-dtr-domain> echo -n | openssl s_client -showcerts -connect itapregistry ...

  3. 10条建议提高PHP代码性能

    这篇文章中的建议涵盖了大部分PHP代码性能方面的问题.如果你是做一些小网站或者小项目,那么有理由忽略这些建议,但是当你为大量用户提供长期稳定的服务的时候,就必须关注了.开发人员必须从项目一开始就考虑这 ...

  4. [Openwrt 项目开发笔记]:Openwrt平台搭建(一)

    [Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 最近开始着手进行Openwrt平台的物联网网关设 ...

  5. C#面向对象编程进阶(一) ——实现栈

    如何用C#编写一个栈类? 关键在于这样的一个类应该如何设计呢?首先要确立面向对象的编程思想,即类是对实体进行合理地抽象和建模,而这种思想将贯彻在我们编程的整个过程中.下面我们一步一步来做. 1.类方法 ...

  6. TCP字节流和UDP数据报区别

    两者的区别在于TCP接收的是一堆数据,而每次取多少由主机决定;而UDP发的是数据报,客户发送多少就接收多少. 拥有这些区别的原因是由于TCP和UDP的特性不同而决定的.TCP是面向连接的,也就是说,在 ...

  7. 【Bugly干货分享】iOS内存管理:从MRC到ARC实践

    Bugly 技术干货系列内容主要涉及移动开发方向,是由Bugly邀请腾讯内部各位技术大咖,通过日常工作经验的总结以及感悟撰写而成,内容均属原创,转载请标明出处. 对于iOS程序员来说,内存管理是入门的 ...

  8. 人人都是 DBA(VIII)SQL Server 页存储结构

    当在 SQL Server 数据库中创建一张表时,会在多张系统基础表中插入所创建表的信息,用于管理该表.通过目录视图 sys.tables, sys.columns, sys.indexes 可以查看 ...

  9. WebAdaptor Object reference not set to an instance of an object.

    C:\inetpub\wwwroot\arcgis目录下webAdaptor.config文件内容被清空,从别的地方拷贝一份即可. <?xml version="1.0" e ...

  10. 《C#图解教程》读书笔记之四:类和继承

    本篇已收录至<C#图解教程>读书笔记目录贴,点击访问该目录可获取更多内容. 一.万物之宗:Object (1)除了特殊的Object类,其他所有类都是派生类,即使他们没有显示基类定义. ( ...