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. Sql 关于 查俩个表 第二个表用到第一个表的某一个数据

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

  2. TurnipBit-MicroPython开发板:跟孩子一起DIY跳动的心

    天是越来越热了,小心脏也是越跳越快啊,为了表达现在激动的心情,必须做个激动的心开始跳动.紧接着就开始带领大家做个激动的心. 首先说说要借助的平台,这次仅仅需要借助一块TurnipBit开发板. Tur ...

  3. Java异常的正确使用姿势

    最近在项目代码中,遇见异常滥用的情形,会带来什么样的后果呢? 1. 代码可读性变差,业务逻辑难以理解 异常流与业务状态流混在一起,无法从接口协议层面理解业务代码,只能深入到方法(Method)内部才能 ...

  4. 【Java框架型项目从入门到装逼】第七节 - 学生管理系统项目搭建

    本次的教程是打算用Spring,SpringMVC以及传统的jdbc技术来制作一个简单的增删改查项目,对用户信息进行增删改查,就这么简单. 1.新建项目 首先,打开eclipse,新建一个web项目. ...

  5. Pandas库的使用--Series

    一.概念 Series相当于一维数组. 1.调用Series的原生方法创建 import pandas as pd s1 = pd.Series(data=[1,2,4,6,7],index=['a' ...

  6. css布局--垂直居中

    1. 使用table-cell和vertical-align实现垂直居中 html <div class="parent">使用table-cell和vertical- ...

  7. Python 接口自动化(预)

    1. HTTP协议:HTTP是接口测试的基础: 2. Fiddler工具:Fiddler所有界面布局及主要布局

  8. ActiveMQ进阶学习

    本文主要讲述ActiveMQ与spring整合的方案.介绍知识点包括spring,jms,activemq基于配置文件模式管理消息,消息监听器类型,消息转换类介绍,spring对JMS事物管理. 1. ...

  9. shader程序员需要注意的优化Tips

    在写shader的时候,其实一些写法对于其执行影响非常大,而且由于gpu和cpu在架构上的不同,代码的优化思想也不一样,最近一直在写几个shader,为了性能问题,查阅了很多资料,把一些tips总结下 ...

  10. dump_stack 分析使用

    dump_stack是用来回溯内核运行的信息的,打印内核信息堆栈段: dump_stack原型: void dump_stack(void); 1.使用这个功能时需要将内核配置勾选上: make me ...