热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

bzoj5403:marshland费用流

DescriptionInputOutputSampleInputInput133101020101013Input233402000403013212231SampleOut

Description
这里写图片描述
Input
这里写图片描述
Output
这里写图片描述
Sample Input

Input 1
3 3 1
0 1 0
2 0 1
0 1 0
1 3
Input 2
3 3 4
0 2 0
0 0 4
0 3 0
1 3
2 1
2 2
3 1

Sample Output

Output 1
3
Output 2
9

Data Constraint
这里写图片描述

分析:
今天模拟赛,出题人做了自己出的题目……
出题人表示看到题目非常尴尬,然后ak了。

x+yx+yx+y为奇数的为黑点,否则为白点。
显然我们选一个黑点,就要在上下两个中选一个白点和一个在左右两个中选一个白点。
那么就可以给费用流建模了。我们把横坐标为偶数的白点放在左边,横坐标为奇数的放右边。黑点分成两个点,这两个点连一条费用为v(x,y)v_{(x,y)}v(x,y)的边,横坐标为偶数的白点点连左边的黑点,右边的黑点连横坐标为奇数的白点,然后连上源汇就好了。显然一次只会加111点流量,所以当跑了mmm次,或最长路为负即可退出(显然不一定要加上所有的点)。
考场上一直在想怎样一次流掉这两个点,一直把这个放在一边,然后就想不出来了。

代码:

/**************************************************************Problem: 5403User: liangzihaoLanguage: C++Result: AcceptedTime:1264 msMemory:3872 kb
****************************************************************/#include
#include
#include
#include const int maxn=1e4+7;
const int maxe=1e5+7;
const int inf=0x3f3f3f3f;using namespace std;int n,m,k,x,ans,cnt,s,t,y;
int ls[maxn],dis[maxn],vis[maxn],pre[maxn],a[100][100],b[maxn];queue q;struct edge{int x,y,w,c,op,next;
}g[maxe];void add(int x,int y,int w,int c)
{g[++cnt]=(edge){x,y,w,c,cnt+1,ls[x]};ls[x]=cnt;g[++cnt]=(edge){y,x,0,-c,cnt-1,ls[y]};ls[y]=cnt;
}int po(int x,int y)
{return (x-1)*n+y;
}bool spfa()
{ while (!q.empty()) q.pop();for (int i&#61;s;i<&#61;t;i&#43;&#43;){dis[i]&#61;-inf;vis[i]&#61;0;}dis[s]&#61;0;q.push(s);vis[s]&#61;1;while (!q.empty()){int x&#61;q.front();q.pop();for (int i&#61;ls[x];i>0;i&#61;g[i].next){int y&#61;g[i].y;if ((g[i].w) && (dis[y]0) return 1;return 0;
}void mcf()
{int i&#61;t,x&#61;1e9;while (i!&#61;s){x&#61;min(x,g[pre[i]].w);i&#61;g[pre[i]].x;}i&#61;t;while (i!&#61;s){g[pre[i]].w-&#61;x;g[g[pre[i]].op].w&#43;&#61;x;ans-&#61;g[pre[i]].c*x;i&#61;g[pre[i]].x;}
}
int main()
{scanf("%d%d%d",&n,&m,&k);s&#61;0; t&#61;n*n*2&#43;1;for (int i&#61;1;i<&#61;n;i&#43;&#43;){for (int j&#61;1;j<&#61;n;j&#43;&#43;){scanf("%d",&a[i][j]);}}for (int i&#61;1;i<&#61;k;i&#43;&#43;){scanf("%d%d",&x,&y);b[po(x,y)]&#61;1;} for (int i&#61;1;i<&#61;n;i&#43;&#43;){for (int j&#61;1;j<&#61;n;j&#43;&#43;){ans&#43;&#61;a[i][j];if (b[po(i,j)]) continue;if ((i&#43;j)%2&#61;&#61;0){if (i%2&#61;&#61;0){add(s,po(i,j),1,0);if (i>1) add(po(i,j),po(i-1,j),1,0);if (j>1) add(po(i,j),po(i,j-1),1,0);if (i1) add(n*n&#43;po(i-1,j),po(i,j),1,0);if (j>1) add(n*n&#43;po(i,j-1),po(i,j),1,0);if (i}
&#xfeff;


推荐阅读
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • IhaveconfiguredanactionforaremotenotificationwhenitarrivestomyiOsapp.Iwanttwodiff ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 本文介绍了Codeforces Round #321 (Div. 2)比赛中的问题Kefa and Dishes,通过状压和spfa算法解决了这个问题。给定一个有向图,求在不超过m步的情况下,能获得的最大权值和。点不能重复走。文章详细介绍了问题的题意、解题思路和代码实现。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 本文介绍了UVALive6575题目Odd and Even Zeroes的解法,使用了数位dp和找规律的方法。阶乘的定义和性质被介绍,并给出了一些例子。其中,部分阶乘的尾零个数为奇数,部分为偶数。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • 实现一个通讯录系统,可添加、删除、修改、查找、显示、清空、排序通讯录信息
    本文介绍了如何实现一个通讯录系统,该系统可以实现添加、删除、修改、查找、显示、清空、排序通讯录信息的功能。通过定义结构体LINK和PEOPLE来存储通讯录信息,使用相关函数来实现各项功能。详细介绍了每个功能的实现方法。 ... [详细]
  • 深入解析Linux下的I/O多路转接epoll技术
    本文深入解析了Linux下的I/O多路转接epoll技术,介绍了select和poll函数的问题,以及epoll函数的设计和优点。同时讲解了epoll函数的使用方法,包括epoll_create和epoll_ctl两个系统调用。 ... [详细]
author-avatar
秋秋传奇哦_729
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有