记录编号 285429 评测结果 AAAAAAAAAAAAAAAAAAAA
题目名称 [HNOI 2013]切糕 最终得分 100
用户昵称 GravatarTenderRun 是否通过 通过
代码语言 C++ 运行时间 0.407 s
提交时间 2016-07-22 15:43:37 内存使用 12.71 MiB
显示代码纯文本
  1. #include <iostream>
  2. #include <cstring>
  3. #include <cstdio>
  4. #include <queue>
  5. using namespace std;
  6. const int maxn=50010;
  7. const int maxm=1000010;
  8. const int INF=1000000000;
  9. int cnt,fir[maxn],to[maxm],nxt[maxm],cap[maxm];
  10. int dis[maxn],gap[maxn],path[maxn],fron[maxn];
  11. queue<int>q;
  12.  
  13. struct Net_Flow{
  14. int tot;
  15. void Init(int tot_){
  16. memset(dis,0,sizeof(dis));
  17. memset(gap,0,sizeof(gap));
  18. memset(fir,0,sizeof(fir));
  19. cnt=1;tot=tot_;
  20. }
  21. void add(int a,int b,int c){
  22. nxt[++cnt]=fir[a];
  23. cap[cnt]=c;
  24. fir[a]=cnt;
  25. to[cnt]=b;
  26. }
  27. void addedge(int a,int b,int c){
  28. add(a,b,c);add(b,a,0);
  29. }
  30. bool BFS(int S,int T){
  31. dis[T]=1;q.push(T);
  32. while(!q.empty()){
  33. int x=q.front();q.pop();
  34. for(int i=fir[x];i;i=nxt[i])
  35. if(!dis[to[i]]){
  36. dis[to[i]]=dis[x]+1;
  37. q.push(to[i]);
  38. }
  39. }
  40. return dis[S];
  41. }
  42. int Max_Flow(int S,int T){
  43. if(!BFS(S,T))return 0;
  44. for(int i=0;i<tot;i++)fron[i]=fir[i];
  45. for(int i=0;i<tot;i++)gap[dis[i]]+=1;
  46. int ret=0,p=S,f,Min;
  47. while(dis[S]<=tot){
  48. if(p==T){
  49. f=INF;
  50. while(p!=S){
  51. f=min(f,cap[path[p]]);
  52. p=to[path[p]^1];
  53. }ret+=f;p=T;
  54. while(p!=S){
  55. cap[path[p]]-=f;
  56. cap[path[p]^1]+=f;
  57. p=to[path[p]^1];
  58. }
  59. }
  60. for(int &i=fron[p];i;i=nxt[i])
  61. if(cap[i]&&dis[to[i]]==dis[p]-1)
  62. {path[p=to[i]]=i;break;}
  63. if(!fron[p]){Min=tot;
  64. if(--gap[dis[p]]==0)break;
  65. for(int i=fir[p];i;i=nxt[i])
  66. if(cap[i])Min=min(Min,dis[to[i]]);
  67. gap[dis[p]=Min+1]+=1;fron[p]=fir[p];
  68. if(p!=S)p=to[path[p]^1];
  69. }
  70. }
  71. return ret;
  72. }
  73. }ISAP;
  74.  
  75. int P,Q,R,D,S,T;
  76. int ID(int i,int j,int k){
  77. if(!k)return 0;
  78. return (k-1)*P*Q+(i-1)*Q+j;
  79. }
  80. int gx[4]={0,-1,0,1};
  81. int gy[4]={1,0,-1,0};
  82. int main(){
  83. freopen("nutcake.in","r",stdin);
  84. freopen("nutcake.out","w",stdout);
  85. scanf("%d%d%d%d",&P,&Q,&R,&D);
  86. S=0;T=P*Q*R+1;ISAP.Init(T+1);
  87. for(int k=1;k<=R;k++)
  88. for(int i=1;i<=P;i++)
  89. for(int j=1,w;j<=Q;j++){
  90. scanf("%d",&w);
  91. ISAP.addedge(ID(i,j,k-1),ID(i,j,k),w);
  92. if(k-D>0){int x,y,z=k-D;
  93. for(int t=0;t<4;t++){
  94. x=i+gx[t];y=j+gy[t];
  95. if(x>0&&x<=P&&y>0&&y<=Q)
  96. ISAP.addedge(ID(i,j,k),ID(x,y,z),INF);
  97. }
  98. }
  99. if(k==R)ISAP.addedge(ID(i,j,k),T,INF);
  100. }
  101. printf("%d\n",ISAP.Max_Flow(S,T));
  102. return 0;
  103. }