http://poj.org/problem?id=3422

题意 : 给你一个N*N的方格,每个格子有一个数字,让你从左上角开始走,只能往下往右走,走过的数字变为0,走K次,问最大能是多大,累加的。

思路 :http://blog.csdn.net/qq172108805/article/details/7857503,这道题挺难的,我也是看的题解。

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <queue>
#include <stdlib.h>
#include <algorithm> using namespace std; const int maxn = ;
const int INF = ;
const int maxm = ; struct node
{
int u,v,c,f,b,next ;
}map[maxm] ;
bool flag[maxn] ;
int cap[][],dist[maxn],pre[maxn],head[maxn] ;
int s,t,n,k,ans,cnt ;
int del,val ; void addedge(int u,int v,int c,int b)
{
map[cnt].u = u ;
map[cnt].v = v ;
map[cnt].c = c ;
map[cnt].b = b ;
map[cnt].f = ;
map[cnt].next = head[u] ;
head[u] = cnt++ ; map[cnt].u = v ;
map[cnt].v = u ;
map[cnt].c = ;
map[cnt].b = -b ;
map[cnt].f = ;
map[cnt].next = head[v] ;
head[v] = cnt++ ;
} void spfa()
{
memset(flag,,sizeof(flag)) ;
queue<int >Q ;
Q.push(s) ;
flag[s] = true ;
while(!Q.empty())
{
int x = Q.front() ;
Q.pop() ;
flag[x] = false ;
for(int i = head[x] ; i+ ; i = map[i].next)
{
int y = map[i].v ;
if(map[i].c > map[i].f && dist[y] < dist[x] + map[i].b)
{
dist[y] = dist[x]+map[i].b ;
pre[y] = i ;
if(!flag[y])
{
flag[y] = true ;
Q.push(y) ;
}
}
}
}
} void mcmf()
{
for( ; ; )
{
memset(dist,-,sizeof(dist)) ;
memset(pre,-,sizeof(pre)) ;
dist[s] = ;
spfa() ;
if(dist[t] == -)
break ;
int minn = INF ;
for(int i = pre[t] ; i+ ; i = pre[map[i].u])
minn = min(minn,map[i].c-map[i].f) ;
for(int i = pre[t] ; i+ ; i = pre[map[i].u])
{
map[i].f += minn ;
map[i^].f -= minn ;
}
ans += dist[t] ;
}
} void Init()
{
cnt = ;
memset(head,-,sizeof(head)) ;
s = ;
t = *n*n+ ;
del = n*n ;
ans = ;
}
int main()
{
scanf("%d %d",&n,&k) ;
Init() ;
for(int i = ; i <= n ; i++)
{
for(int j = ; j <= n ; j++)
scanf("%d",&cap[i][j]) ;
}
addedge(s,,k,) ;
addedge(n*n+del,t,k,) ;
for(int i = ; i <= n ; i++)
{
for(int j = ; j <= n ; j++)
{
val = (i-)*n+j ;
addedge(val,val+del,,cap[i][j]) ;
addedge(val,val+del,INF,) ;
if(j != n) addedge(val+del,val+,INF,) ;
if(i < n) addedge(val+del,val+n,INF,) ;
}
}
mcmf() ;
printf("%d\n",ans) ;
return ;
}

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

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

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

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

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

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

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

  4. POJ 3422 Kaka's Matrix Travels

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

  5. poj3422 Kaka's Matrix Travels(最小费用最大流问题)

    /* poj3422 Kaka's Matrix Travels 不知道 k次 dp做为什么不对??? 看了大牛的代码,才知道还可以这样做! 开始没有理解将a 和 a‘ 之间建立怎样的两条边,导致程序 ...

  6. POJ 3422 Kaka's Matrix Travels (K取方格数:最大费用流)

    题意 给出一个n*n大小的矩阵,要求从左上角走到右下角,每次只能向下走或者向右走并取数,某位置取过数之后就只为数值0,现在求解从左上角到右下角走K次的最大值. 思路 经典的费用流模型:K取方格数. 构 ...

  7. poj 3422 Kaka's Matrix Travels 费用流

    题目链接 给一个n*n的矩阵, 从左上角出发, 走到右下角, 然后在返回左上角,这样算两次. 一共重复k次, 每个格子有值, 问能够取得的最大值是多少, 一个格子的值只能取一次, 取完后变为0. 费用 ...

  8. POJ 3422 Kaka's Matrix Travels(拆点+最大费用流)题解

    题意:小A从左上角走到右下角,每个格子都有一个价值,经过这个格子就把价值拿走,每次只能往下或往右走,问你走k次最多能拿多少价值的东西. 思路:这里有一个限制条件就是经过之后要把东西拿走,也就是每一格的 ...

  9. POJ 3422 Kaka's Matrix Travels K取方格数

    题目:给出n*n的方格矩阵,现在从左上方走m次到右下方,问m次能够获得的最大价值和. 分析:最大费用流.拆点进行限制每个格子只取一次,假设点x拆成 x,xx,右边(假设有)y,yy,下方(假设有)z, ...

随机推荐

  1. symonfy 项目根目录下没有 bin/console 文件的解决方法

    “Could not open input file: bin/console” Error comes when try to Run the Symfony Application 在采纳的答案中 ...

  2. ttt

    <style> .head1{ background:rgb(51,51,51); height:49px; min-width:1241px; width:100%; z-index:1 ...

  3. iOS开发--Swift RAC响应式编程

    时间不是很充足, 先少说点, RAC的好处是响应式编程, 不需要自己去设置代理委托, target, 而是主要以信息流(signal), block为主, 看到这里激动吧, 它可以帮你监听你的事件, ...

  4. MySQL索引详解

    导读:大家都知道,一个MySQL数据库能够储存大量的数据,如果要查找那一个数据,就得费好大劲从一大堆的数据中找到,即费时间又费力气,这时,索引的出现就大大减轻了数据库管理员的工作.本文介绍了数据库索引 ...

  5. Innosetup打包自动下载.net framework 动态库及替换卸载程序图标.

    在使用了一段时间微软自带的安装包打包工具后,总感觉不太顺利,于是便想着找一种更简单稳定的打包工具,这类工具其实还不少,最终经过各种考量,我们选择了 InnoSetup , 该工具是一个完全免费的Win ...

  6. 使用repeater控件显示列表替代treeview

    using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...

  7. Sencha Touch id 和 itemId

    通过id获得组件: var view=Ext.getCmp('id'); 通过itemId获得组件: var view = ComponentQuery.query('view_xtype'), // ...

  8. iBeacon 开发笔记

    iBeacon开发笔记 2015.10.19 airlocate ========= airlocate显示如何使用这个监控范围clbeaconregions. 代码还提供了一个例子,你如何能校准和配 ...

  9. GDI+中发生一般性错误之文件被占用

    有多种原因可能导致这个异常出现,比如创建文件的权限不足.文件被占用等. 这里提供一个使用Stream读取图片避免文件被占用的方法. public Image GetImageFromStream(st ...

  10. [.Net MVC] 使用 log4net 日志框架

    项目:后台管理平台 意义:项目开发中提出增加日志功能,对关键的操作.程序运行中的错误信息进行记录,这对程序部署后的调试有很大意义. 注:本文只是对网上搜集的信息进行了整合,以备今后查询. 关键字:.N ...