众所周知,LZF很喜欢打一个叫Jubeat的游戏。这是个音乐游戏,游戏界面是4×4的方阵,会根据音乐节奏要求玩家按下一些指定方块(如下称combo)。LZF以为这太简单了,因而本身仿了个游戏叫Jubeeeeeat,惟一不一样之处就是界面大小,Jubeeeeeat的界面为n×n的方阵。ios
在某一刻,界面同时出现了若干个combo。LZF终于以为有些困难了,但毕竟LZF不是普通人,他有不少只手。LZF的手分为m只“肉质手”和q只“意念手”。顾名思义,“肉质手”是实际存在的手,每只肉质手都有5根手指,每根手指能按一个combo,但每只手的速度都不一样,受限于此,LZF的每只肉质手的控制范围是一个固定大小的正方形。“意念手”即虚无之手,每只手只有1根手指,但控制范围为全局。网络
如今LZF想知道,他最多能按下多少个combo。spa
3 1 3 1 0 1 1 1 1 1 0 1 1 1 2
6
#include<queue> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define N 200100 #define inf 9999999 using namespace std; queue<int>q; int n,p,m,x,y,z,s,e,ans,maxn,tot=1,a[100][100]; int to[N],lev[N],cap[N],cnt[N],head[N],nextt[N]; int read() { int x=0,f=1; char ch=getchar(); while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar(); return x*f; } int add(int x,int y,int z) { tot++;to[tot]=y,cap[tot]=z,nextt[tot]=head[x];head[x]=tot; tot++;to[tot]=x;cap[tot]=0,nextt[tot]=head[y];head[y]=tot; } inline bool bfs() { while(!q.empty()) q.pop(); for(int i=0;i<=n*n+m+1;i++) { lev[i]=-1; cnt[i]=head[i]; } q.push(s),lev[s]=0; while(!q.empty()) { int x=q.front();q.pop(); for(int i=head[x];i;i=nextt[i]) { int t=to[i]; if(cap[i]>0&&lev[t]==-1) { lev[t]=lev[x]+1; q.push(t); if(t==e) return true; } } } return false; } int dinic(int x,int flow) { if(x==e) return flow; int rest=0,delta; for(int &i=cnt[x];i;i=nextt[i]) { int t=to[i]; if(cap[i]>0&&lev[t]==lev[x]+1) { delta=dinic(t,min(cap[i],flow-rest)); if(delta) { rest+=delta; cap[i]-=delta; cap[i^1]+=delta; if(rest==flow) break; } } } if(rest!=flow) lev[x]=-1; return rest; } int main() { n=read(),m=read(),p=read(); for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) { a[i][j]=read(); if(a[i][j]) maxn++; } e=n*n+m+1; for(int i=1;i<=m;i++) add(s,i,5); for(int i=1;i<=m;i++) { x=read(),y=read(),z=read(); for(int j=x;j<x+z;j++) for(int k=y;k<y+z;k++) if(a[j][k]) add(i,m+(j-1)*n+k,1); } for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) if(a[i][j]) add(m+(i-1)*n+j,e,1); while(bfs()) ans+=dinic(s,inf); ans=min(ans+p,maxn); printf("%d",ans); return 0; }