Tyvj-1338 QQ农场
背景
描述
在每块土地上,都种有一种农作物。如果他选择摘取一块土地上的农作物,就能获得一个固定的利润(当然,这个利润是正数)。不同土地上的利润多半是不同的。
贪心的Sandytea本想摘取所有土地上的农作物。但是正当他准备行动时,却被告知不允许摘取了两块有公共边的土地上的作物,否则就会被主人的狗发现。
Sandytea想知道,在不被狗抓住的前提下,他能获得的最大利益是多少。
输入格式
下面N行:每行N个正整数,描述了各块土地上的农作物的单位价值。
输出格式
测试样例1
输入
2
7 7
54 54
输出
61
备注
有10分的数据满足:N≤6
另有20分的数据满足:N≤13
另有30分的数据满足:N≤50
另有40分的数据满足:N≤200
所有数据满足:每块土地上作物的价值不超过100。改编自SPOJ
题解:
把格子交替染成不同颜色(即分成两部分),这样相邻的格子颜色不同,就转化成了一个二分图匹配的问题。源点s向每个白格子连流量等于土地价值的边,黑格子向汇点t连,黑白格子之间连流量为inf的边,求最小割。
注意不要把边建重了。由于每个黑格子可能会被重复连,所以不应该在每次连黑白格子之间的边时,连黑格子到t的边
#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstdio>
#define nn 40010 //因为是矩形,所以要n*n
#define mm 1000010
#define inf 2000000001
using namespace std;
int get()
{
int ans=0,f=1;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)) {ans=ans*10+ch-'0';ch=getchar();}
return ans*f;
}
int x[4]={1,-1,0,0},y[4]={0,0,1,-1};
int e=0,n,ss,tt,fir[nn],nxt[mm],to[mm],flow[mm],q[nn],dep[nn],f[210][210];
void add(int a,int b,int c)
{
nxt[++e]=fir[a];fir[a]=e;to[e]=b;flow[e]=c;
nxt[++e]=fir[b];fir[b]=e;to[e]=a;flow[e]=0;
}
bool il(int x,int y)
{
if(x>0&&x<=n&&y>0&&y<=n) return 1;return 0;
}
bool bfs()
{
int h=1,t=1,o;
q[1]=ss;
while(h<=t)
{
o=q[h++];
for(int i=fir[o];i;i=nxt[i])
if(flow[i]&&!dep[to[i]])
{
dep[to[i]]=dep[o]+1;
q[++t]=to[i];
}
}
if(dep[tt]) return 1;
return 0;
}
int maxflow(int s,int f)
{
if(!f||s==tt) return f; //写成了return 0
int newflow,newans=0;
for(int i=fir[s];i;i=nxt[i])
if(dep[to[i]]==dep[s]+1&&flow[i])
{
newflow=maxflow(to[i],min(f,flow[i])); //流量要和flow[i]取min
f-=newflow;
flow[i]-=newflow;
flow[((i-1)^1)+1]+=newflow;
newans+=newflow;
if(!f) break;
}
if(f>0)
dep[s]=-1; //神奇的优化
return newans;
}
int main()
{
n=get();ss=0,tt=n*n+1;
int ans=0;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
f[i][j]=get();
ans+=f[i][j];
}
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if((i+j)%2)
{
add(ss,(i-1)*n+j,f[i][j]); //开始写到下一个for里面了,然后就加重了
for(int k=0;k<4;k++)
if(il(i+x[k],j+y[k]))
add((i-1)*n+j,(i+x[k]-1)*n+j+y[k],inf); //一开始在这里加了到tt的边,然后就加重了
}
else
add((i-1)*n+j,tt,f[i][j]);
dep[ss]=1;
while(bfs())
{
ans-=maxflow(ss,inf);
for(int i=1;i<=tt;i++) //算上ss、tt
dep[i]=0;
dep[ss]=1;
}
printf("%d",ans);
return 0;
}
/*
3
3 42 26
81 26 36
68 52 71 6
76 53 11 42 48 27
19 78 74 46 22 57
14 2 33 62 15 62
23 62 39 95 91 69
45 36 62 44 91 70
10 7 97 67 66 68
*/
Tyvj-1338 QQ农场的更多相关文章
- 【TYVJ】1338 QQ农场(最大流+最大权闭合图)
http://tyvj.cn/Problem_Show.aspx?id=1338 时间才排到rank7,还不快啊囧.isap我常数都写得那么小了... 最大权闭合图看我另一篇博文吧 此题很明显的模型. ...
- TYVJ1338 QQ农场
时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 Sandytea前段时间沉迷于QQ农场中……一天夜里,他梦见来到好友X的农场上…… 描述 这个农场和游戏中略有 ...
- 关于QQ农场牧场等曾经流行的游戏的一些见解
大概在上上周,我偶然间打开QQ空间玩了一会QQ农牧场,玩完之后我在想,在那个年代他们为什么那么红? 我觉得可能有以下几点: 1:凭借着QQ海量的用户,可以迅速推广 2:迎合了人们爱占小便宜的心理,不过 ...
- UU农场平台开发 UU农场拆复利系统
UU农场平台开发 UU农场拆复利系统今年比较新的一款游戏,类似于QQ农场,但又加入了很多新型的互联网理财模式!UU农场平台开发 UU农场拆复利系统.UU农场开发.UU农场游戏平台开发.UU农场平台开发 ...
- 游戏全区全服和分区分服 QQ斗地主的设计
游戏全区全服和分区分服 QQ斗地主的设计 https://cloud.tencent.com/community/article/164816001481011910?fromSource=gwzc ...
- JAVA上百实例源码以及开源项目
简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级.中级.高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情.执着,对IT的憧憬. ...
- 2014年5月份第1周51Aspx源码发布详情
郑州某高校学生考评系统源码 2014-5-5 [VS2008]功能介绍: 1.用户角色有部主任.教师.学生等. 2.可添加班级考评项目.学生考评项目. 3.可指定学生对班级.学生某考评项 ...
- Java NIO教程 前言
阅读本文前,建议你先了解 旧I/O NIO 是 New I/O 的缩写,要了解它真正的内涵,需要掌握的知识还是比较多的.我努力在这几篇笔记里,勾勒出整个io的面貌.为大家的深入学习铺路. I/O简史 ...
- 制作便携版 FireFox 火狐浏览器
Firefox是一款可高度自定义的开源浏览器: 你可以访问 火狐DIY 定制自己的Firefox安装包, 此外,你还可以自己动手定制一款可以放在U盘随身携带的便携版Firefox火狐浏览器. 制作便携 ...
随机推荐
- 备忘录模式(Memento、Originator、Caretaker)(状态保存,备份恢复)
定义:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样就可以将该对象恢复到原先保存的状态 类型:行为类 类图: 我们在编程的时候,经常需要保存对象的中间状态,当需要的时 ...
- VI/VIM编辑器快捷键
常用快捷键: Ctrl+f 向下翻页 Ctrl+b 向上翻页 G 移动到文件最后一行 gg 移动到文件第一行 N+回车 ...
- Codeforces 455C
题目链接 C. Civilization time limit per test 1 second memory limit per test 256 megabytes input standard ...
- SimpleDateFormat 以及java8 - DateTimeFormatter
https://www.cnblogs.com/zhisheng/p/9206758.html 在看的过程中有这么一条: [强制]SimpleDateFormat 是线程不安全的类,一般不要定义为 s ...
- Microsoft: Get started with Dynamic Data Masking in SQL Server 2016 and Azure SQL
Dynamic Data Masking (DDM) is a new security feature in Microsoft SQL Server 2016 and Azure SQL DB. ...
- Polyfill简介
1.什么是Polyfill? Polyfill是一个js库,主要抚平不同浏览器之间对js实现的差异.比如,html5的storage(session,local), 不同浏览器,不同版本,有些支持,有 ...
- python2与python3爬虫中get与post对比
python2中的urllib2改为python3中的urllib.request 四种方式对比: python2的get: # coding=utf-8 import urllib import u ...
- python 初始化init方法
- 【JZOJ4860】【NOIP2016提高A组集训第7场11.4】分解数
题目描述 Dpstr学习了动态规划的技巧以后,对数的分解问题十分感兴趣. Dpstr用此过程将一个正整数x分解成若干个数的乘积:一开始令集合A中只有一个元素x,每次分解时从A中取一个元素a并找出两个大 ...
- Project configuration is not up-to-date with pom.xml. Run Maven->Update Project or use Quick Fix
版权声明:本文为 testcs_dn(微wx笑) 原创文章,非商用自由转载-保持署名-注明出处.谢谢. https://blog.csdn.net/testcs_dn/article/details/ ...