这题就是真正的费用流了,用 大屁 就算不超时,你也有个 CE :数组 so large

拆点,费用取反,最大费用最大流即可了喵~

不过似乎这题很不兼容 dijkstra 的样子

就算用 spfa 重赋权把边权搞正后依然 TLE ,额不是说 dijstra 正权图最强么?

一定是我没有手写堆,一定是的……

#include <cstdio>
#include <cstring>
#include <queue>
#define min(x, y) ((x)<(y) ? (x):(y))
const int inf=0x7F7F7F7F;
const int sizeOfPoint=800008;
const int sizeOfEdge=8000008; int n;
int V;
int S, T;
int a[666][666][2];
bool vis[sizeOfPoint];
int h[sizeOfPoint];
inline int getint();
inline void putint(int); struct edge {int point, flow, cost; edge * next, * pair;};
edge memory[sizeOfEdge], * port=memory;
edge * e[sizeOfPoint];
inline void clear() {port=memory; memset(e, 0, sizeof e); memset(a, 0, sizeof a);}
inline edge * newedge(int point, int flow, int cost, edge * next)
{
edge * ret=port++;
ret->point=point; ret->flow=flow; ret->cost=cost; ret->next=next;
return ret;
}
inline void link(int u, int v, int f, int c)
{
e[u]=newedge(v, f, c, e[u]); e[v]=newedge(u, 0, -c, e[v]);
e[u]->pair=e[v]; e[v]->pair=e[u];
}
inline bool spfa();
int aug(int, int);
inline int costflow(); int main()
{
while (scanf("%d", &n)!=EOF)
{
clear();
V=0;
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
{
a[i][j][0]=++V; a[i][j][1]=++V;
link(a[i][j][0], a[i][j][1], 1, -getint());
} link(a[1][1][0], a[1][1][1], 1, 0);
link(a[n][n][0], a[n][n][1], 1, 0);
S=1; T=V;
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
{
if (i<n) link(a[i][j][1], a[i+1][j][0], 1, 0);
if (j<n) link(a[i][j][1], a[i][j+1][0], 1, 0);
}
putint(-costflow());
} return 0;
} inline int getint()
{
register int num=0;
register char ch;
do ch=getchar(); while (ch<'0' || ch>'9');
do num=num*10+ch-'0', ch=getchar(); while (ch>='0' && ch<='9');
return num;
}
inline void putint(int num)
{
char stack[15];
register int top=0;
for ( ;num;num/=10) stack[++top]=num%10+'0';
for ( ;top;top--) putchar(stack[top]);
putchar('\n');
} inline bool spfa()
{
static std::queue<int> q;
static bool inque[sizeOfPoint];
memset(h, 0x7F, sizeof h); h[T]=0;
memset(inque, 0, sizeof inque);
for (inque[T]=true, q.push(T);q.size();q.pop())
{
int u=q.front();
inque[u]=false;
for (edge * i=e[u];i;i=i->next) if (i->pair->flow && h[i->point]>h[u]+i->pair->cost)
{
h[i->point]=h[u]+i->pair->cost;
q.push(i->point);
if (!inque[i->point]) inque[i->point]=true, q.push(i->point);
}
}
return h[S]<inf;
}
int aug(int u, int flow)
{
int left=flow;
if (u==T) return flow;
vis[u]=true;
for (edge * i=e[u];i;i=i->next) if (!vis[i->point] && i->flow && h[u]==h[i->point]+i->cost)
{
int temp=aug(i->point, min(left, i->flow));
i->flow-=temp; i->pair->flow+=temp; left-=temp;
if (!left) break;
}
vis[u]=false;
return flow-left;
}
inline int costflow()
{
int ret=0;
while (spfa())
ret+=h[S]*aug(S, inf);
return ret;
}

[hdu 3376]Matrix Again的更多相关文章

  1. POJ 2135 Farm Tour &amp;&amp; HDU 2686 Matrix &amp;&amp; HDU 3376 Matrix Again 费用流求来回最短路

    累了就要写题解,近期总是被虐到没脾气. 来回最短路问题貌似也能够用DP来搞.只是拿费用流还是非常方便的. 能够转化成求满流为2 的最小花费.一般做法为拆点,对于 i 拆为2*i 和 2*i+1.然后连 ...

  2. hdu 3376 : Matrix Again【MCMF】

    题目链接 题意:给定一个n*n的矩阵,找一条路,从左上角到右下角再到左上角,每个点最多经过一次,求路径上的点的权值的最大和. 将矩阵中每个点拆点,点容量为1,费用为点权值的相反数.每个点向自己右侧和下 ...

  3. HDU 2686 Matrix 3376 Matrix Again(费用流)

    HDU 2686 Matrix 题目链接 3376 Matrix Again 题目链接 题意:这两题是一样的,仅仅是数据范围不一样,都是一个矩阵,从左上角走到右下角在从右下角走到左上角能得到最大价值 ...

  4. hdu 2686&&hdu 3376(拆点+构图+最小费用最大流)

    Matrix Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  5. HDU 4920 Matrix multiplication(bitset)

    HDU 4920 Matrix multiplication 题目链接 题意:给定两个矩阵,求这两个矩阵相乘mod 3 思路:没什么好的想法,就把0的位置不考虑.结果就过了.然后看了官方题解,上面是用 ...

  6. HDU 3376 费用流 Matrix Again

    题意: 给出一个n × n的矩阵,每个格子中有一个数字代表权值,找出从左上角出发到右下角的两条不相交的路径(起点和终点除外),使得两条路径权值之和最大. 分析: 如果n比较小的话是可以DP的,但是现在 ...

  7. hdu 2686 Matrix 最小费用最大流

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2686 Yifenfei very like play a number game in the n*n ...

  8. hdu 5569 matrix dp

    matrix Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5569 D ...

  9. HDU 3376

    http://acm.hdu.edu.cn/showproblem.php?pid=3376 题意:一个矩阵,每个点有价值,起点左上角终点右下角,每次只能走当前点的下一点或右一点,从起点走到终点,再从 ...

随机推荐

  1. Python学习(14)模块二

    一:_name_ Python中if _name_ == '_main_'的解析 当你打开一个.py文件时,经常会在代码的最下面看到if __name__ == '__main__':,现在就来介 绍 ...

  2. win7文件夹图标中多了一把小锁打不开文件夹怎么办?

    win7文件夹图标中多了一把小锁打不开文件夹怎么办?解决办法一:右击目录→取得管理员权限!该方法适用于win7旗舰版.解决办法二:右击目录→属性→安全→高级→选择everyone→更改权限→勾上完全访 ...

  3. python + selenium相关事件和元素定位

    女友由于工作上的失误,将公司RDM中的某一字段的2000条数据给删除了.....就算是重新添加字段,但是与其他数据的关联性已经不在了.由于每天的数据修改量大,有关部门不愿意恢复数据库,因此只能一条条的 ...

  4. ruby bundle config 镜像映射配置

    新增映射 : bundle config mirror.https://rubygems.org/ http://ruby.taobao.com #所有对source https://rubygems ...

  5. 通过 Informix 系统表监控和优化数据库

    Informix 数据库系统字典表简介 Informix 数据库服务器运行时的状态信息是数据库管理员 DBA 进行系统监控和优化的必需信息来源.Informix 的状态信息在内部以 2 种方式存在,如 ...

  6. json 解析 真是一篇让我泪流满面的好文章

    http://my.eoe.cn/iceskysl/archive/19629.html点击打开链接

  7. CSS3判断手机横屏竖屏

    原理: 当用户旋转屏幕的时候,会进入到你的监听方法中,然后通过window.orientation来获取当前屏幕的状态:0 - 竖屏90 - 逆时针旋转横屏-90 - 顺时针旋转横屏180 - 竖屏, ...

  8. 【必备】史上最全的浏览器 CSS & JS Hack 手册(转)

    浏览器渲染页面的方式各不相同,甚至同一浏览器的不同版本(“杰出代表”是 IE)也有差异.因此,浏览器兼容成为前端开发人员的必备技能.如果有一份浏览器 Hack 手册,那查询起来就方便多了.这篇文章就向 ...

  9. R语言apply函数族笔记

    为什么用apply 因为我是一个程序员,所以在最初学习R的时候,当成“又一门编程语言”来学习,但是怎么学都觉得别扭.现在我的看法倾向于,R不是一种通用型的编程语言,而是一种统计领域的软件工具.因此,不 ...

  10. C#测试web服务是否可用

    winform客户端经常需要调用webservice或者WCF进行数据交互,但是远程服务有可能不存在或者服务器不可用,客户端只能通过超时或者捕获到异常感知服务不可用.其实有一个COM借口可用快速的检测 ...