P2045 方格取数加强版

题目描述

给出一个n*n的矩阵,每一格有一个非负整数Aij,(Aij <= 1000)现在从(1,1)出发,可以往右或者往下走,最后到达(n,n),每达到一格,把该格子的数取出来,该格子的数就变成0,这样一共走K次,现在要求K次所达到的方格的数的和最大

输入输出格式

输入格式:

第一行两个数n,k(1<=n<=50, 0<=k<=10)

接下来n行,每行n个数,分别表示矩阵的每个格子的数

输出格式:

一个数,为最大和

输入输出样例

输入样例#1: 复制

3 1
1 2 3
0 2 1
1 4 2
输出样例#1: 复制

11

说明

每个格子中的数不超过1000

相信一定有一些人一看到N<=50就想搜索(233……),但是显然TLE。

那么对于K<=10,我记得当k<=2时,貌似用DP也能做。

这题的坑就在于“加强版”,其实这题是个图论。

再看看,不难想到这是网络流“最大流最大消费”,再看到aij<=1000,便可以将每个数取负数,就最小消费流即可。

怎么建图,是网络流中的难点。

因为每个点只能去一次,所以拆成两点,这两点之间有两条路,一条只能走一次(流量为1),但可以取到数(费用为-aij)

另一点最多能走k次,取不到数。

有人喜欢建超级源点和汇点(因为只取k次),其实不用如此。

我们从1,1点出发SPFAk次即可,注意如果有一次到不了终点直接结束!

OK,就这样AC了。注意点的位置,我用的是pos(i,j)=(i-1)*n+j,比较方便。

AC代码如下:

#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
#define pos(i,j)  (i-1)*n+j
using namespace std;
+;
*;
struct p
{
    int to,w,cost,nxt;
}e[M];
],dis[N<<],pre[N<<];
];
int x,num,n,k,cnt;
void add(int u,int v,int ds,int cst)
{
    e[cnt].nxt=h[u];
    e[cnt].to=v;
    e[cnt].w=ds;
    e[cnt].cost=cst;
    h[u]=cnt;
    cnt++;
    e[cnt].nxt=h[v];
    e[cnt].to=u;
    e[cnt].w=;
    e[cnt].cost=-cst;
    h[v]=cnt;
    cnt++;
}
int solve()
{
    ;
    while(k--)
    {
        memset(dis,0x3f,sizeof(dis));
        memset(pre,-,sizeof(pre));
        queue<int>q;
        q.push();
        dis[]=;
        while(!q.empty())
        {
            int now=q.front();
            q.pop();inq[now]=;
            ;i=e[i].nxt)
              if(e[i].w&&dis[e[i].to]>dis[now]+e[i].cost)
              {
                  dis[e[i].to]=dis[now]+e[i].cost;
                  pre[e[i].to]=i;
                  ;
              }
        }
        ) return -ans;
        ,j=n*n+N;
        )
        {
            mx=min(mx,e[pre[j]].w);
            j=e[pre[j]^].to;
        }
        j=n*n+N;
        )
        {
            ans+=e[pre[j]].cost*mx;
            e[pre[j]].w-=mx;
            e[pre[j]^].w+=mx;
            j=e[pre[j]^].to;
        }
    }
    return -ans;
}
int main()
{
    memset(h,-,sizeof(h));
    scanf("%d%d",&n,&k);
    ;i<=n;i++)
    ;j<=n;j++)
    {
    scanf("%d",&x);
    num=pos(i,j);
    add(num,num+N,,-x);add(num,num+N,k,);
    ,j),k,);
    ),k,);
    }
    printf("%d",solve());
    ;
}

P2045 方格取数加强版的更多相关文章

  1. 洛谷 P2045 方格取数加强版【费用流】

        题目链接:https://www.luogu.org/problemnew/show/P2045 题目描述 给出一个n*n的矩阵,每一格有一个非负整数Aij,(Aij <= 1000)现 ...

  2. P2045 方格取数加强版 最大费用最大流

    $ \color{#0066ff}{ 题目描述 }$ 给出一个n*n的矩阵,每一格有一个非负整数Aij,(Aij <= 1000)现在从(1,1)出发,可以往右或者往下走,最后到达(n,n),每 ...

  3. [洛谷P2045]方格取数加强版

    题目大意:有一个n*n的矩阵,每个格子有一个非负整数,规定一个人从(1,1)开始,只能往右或下走,走到(n,n)为止,并把沿途的数取走,取走后数变为0.这个人共取n次,求取得的数的最大总和. 解题思路 ...

  4. 洛谷 - P2045 - 方格取数加强版 - 费用流

    原来这种题的解法是费用流. 从一个方格的左上走到右下,最多走k次,每个数最多拿走一次. 每次走动的流量设为1,起始点拆点成限制流量k. 每个点拆成两条路,一条路限制流量1,费用为价值相反数.另一条路无 ...

  5. bzoj P2045 方格取数加强版【最大费用最大流】

    今天脑子不太清醒,把数据范围看小了一直TTTTLE-- 最大费用最大流,每个格子拆成两个(x,y),(x,y)',(x,y)向(x,y)'连一条费用a[x][y]流量1的边表示选的一次,再连一条费用0 ...

  6. 洛谷P2045 方格取数加强版(费用流)

    题意 题目链接 Sol 这题能想到费用流就不难做了 从S向(1, 1)连费用为0,流量为K的边 从(n, n)向T连费用为0,流量为K的边 对于每个点我们可以拆点限流,同时为了保证每个点只被经过一次, ...

  7. 【Luogu】P2045方格取数加强版(最小费用最大流)

    题目链接 通过这题我学会了引诱算法的行为,就是你通过适当的状态设计,引诱算法按照你想要它做的去行动,进而达到解题的目的. 最小费用最大流,首先将点拆点,入点和出点连一条费用=-权值,容量=1的边,再连 ...

  8. 洛谷P2045 方格取数加强版 最小费用流

    Code: #include<cstdio> #include<cstring> #include<algorithm> #include<queue> ...

  9. [luogu_P2045]方格取数加强版

    [luogu_P2045]方格取数加强版 试题描述 给出一个 \(n \times n\) 的矩阵,每一格有一个非负整数 \(A_{i,j},(A_{i,j} \le 1000)\) 现在从 \((1 ...

随机推荐

  1. python 发信实例

    转自:http://www.cnblogs.com/lonelycatcher/archive/2012/02/09/2343463.html 文件形式邮件   #!/usr/bin/env pyth ...

  2. Sql 关于 查俩个表 第二个表用到第一个表的某一个数据

    今天在写程序的时候遇到一个问题  有一个这个需求 select top 1 Name,[Address] from UserInfo;select * from shoppingAddress whe ...

  3. Mysql查询不为null值

    Mysql本以为查询不为null就是!=null可是结果查询出来什么都没有,后来才发现不为null应该是is not null ,为null应该是is null.

  4. duilib基本流程

    duilib的基本流程如上图,通过解析一个xml文件,将文件中的内容渲染为窗口界面,这个解析过程由WindowImplBase类来完成. 基本框架如下: 1. 首先在公共头文件中加入如下内容: #in ...

  5. MySQL在并发场景下的问题及解决思路

    目录 1.背景 2.表锁导致的慢查询的问题 3.线上修改表结构有哪些风险? 4.一个死锁问题的分析 5.锁等待问题的分析 6.小结 1.背景 对于数据库系统来说在多用户并发条件下提高并发性的同时又要保 ...

  6. 2017-07-18&19

    [toc] 数据库 for循环里写操作数据库是大忌!尤其是这种情况:一次查询的结果中有一个记录还要继续展开查询,两次查询的记录均不止一条.就很容易写成for循环里操作数据库了.解决办法就是循环里的每条 ...

  7. 【算法】赫夫曼树(Huffman)的构建和应用(编码、译码)

    参考资料 <算法(java)>                           — — Robert Sedgewick, Kevin Wayne <数据结构>       ...

  8. django笔记整理

    Django复习: MTV模型: manager启动服务→urls找到路径→(找到views视图函数或者做路由分发)→视图函数处理相关逻辑,返回一个模板或者是字符串: ---------------- ...

  9. Codeforces 915E Physical Education Lessons

    原题传送门 我承认,比赛的时候在C题上卡了好久(最后也不会),15min水掉D后(最后还FST了..),看到E时已经只剩15min了.尽管一眼看出是离散化+线段树的裸题,但是没有时间写,实在尴尬. 赛 ...

  10. Codeforces Beta Round #1 A,B,C

    A. Theatre Square time limit per test:1 second memory limit per test:256 megabytes input:standard in ...