题目描述

网址:https://daniu.luogu.org/problemnew/show/3227
大意:
平面上有一长方体,目标为将其切割为上下两半。
切割点为\((x,y,z)\)的点,每个点有一个不和谐值v,现在有两个要求:

  • [1]任何两个平面相邻的切割点之间的高度差不能超过D
  • [2]要使得最终的不和谐值最小。
    求解最小的$ ∑vi $

题目解法

直接建图,化点为边。将最下面的点与S相连,最上面的与T相连。
然后跑最小割即为答案。
现在关键在于如何限制高度差不超过D。
以\((x,y,z)\)与\((x+1,y,z)\)为例。
建立\((x,y,z) —>(x+1,y,z-D)\) 与 \((x+1,y,z+D+1)—>(x,y,z+1)\)两条边
那么在割断\((x,y,z)->(x,y,z+1)\)时,就可保证\((x+1,y)\)上割的为题目所限制范围。
动手画一下就明白了。 如果割超出范围的边,S、T依旧联通。
所以用上述方法建图,然后跑最小割即可得到答案。

实现代码

#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<cstring>
#include<cmath>
#include<queue>
#include<algorithm>
#define ll long long
#define RG register
#define IL inline
#define maxn 125000
#define INF 1e16+7
using namespace std;

IL ll gi(){
    RG ll date = 0, m = 1;  RG char ch = 0;
    while(ch!='-'&&(ch<'0'||ch>'9'))ch = getchar();
    if(ch == '-'){m = -1; ch = getchar();}
    while(ch>='0' && ch<='9')
       {date=date*10+ch-'0'; ch = getchar();}
    return date*m;
}

ll cnt,Q,P,R,S,T,D;
ll vis[maxn],dep[maxn],head[maxn],cur[maxn];
ll mx[4] = {0,0,-1,1},my[4] = {-1,1,0,0};
struct Road { ll to,next,cap,flow; }t[20*maxn];

IL bool Bfs(){
    for(RG ll i = 0; i <= T; i ++)vis[i] = 0;
    dep[S] = 0; vis[S] = 1; queue<ll>Que; Que.push(S);
    while(!Que.empty()){
        RG ll u = Que.front(); Que.pop();
        for(RG ll i = head[u]; i!= -1; i = t[i].next){
            RG ll v = t[i].to;
            if(!vis[v] && t[i].cap > t[i].flow){
                dep[v] = dep[u] + 1;
                vis[v] = true; Que.push(v);
            }
        }
    }return vis[T];
}

int Dfs(RG ll u,RG ll Lim){
    if(u == T || Lim == 0)return Lim;
    RG ll flow =0,f = 0;
    for(RG ll &i = cur[u]; i != -1; i = t[i].next){
        RG ll v = t[i].to;
        if(dep[v] == dep[u] + 1 && (f = Dfs(v,min(Lim,t[i].cap-t[i].flow))) > 0){
            flow += f; Lim -= f;
            t[i].flow += f; t[(i^1)].flow -= f;
            if(Lim == 0)break;
        }
    }return flow;
}

IL int Dinic(){
    RG ll Flow = 0;
    while(Bfs()){
        for(RG ll i = 0; i <= T; i ++)cur[i] = head[i];
        Flow += Dfs(S,INF);
    }return Flow;
}

IL ll Cod(RG ll z,RG ll x,RG ll y){
    return z*(P*Q) + (x-1)*Q + y;
}

IL void Add(ll uu,ll vv,ll cc){
    t[cnt++] = (Road){vv,head[uu],cc,0}; head[uu] = cnt - 1;
    t[cnt++] = (Road){uu,head[vv],0,0};  head[vv] = cnt - 1;
}

int main(){
    freopen("testdate.in","r",stdin);
    P = gi(); Q = gi(); R = gi(); D = gi();
    S = 0; T = R*P*Q+P*Q+1;
    for(RG ll i = 0; i <= T; i ++)head[i] = -1;
    for(RG ll h = 1; h <= R; h ++)
        for(RG ll i = 1; i <= P; i ++)
            for(RG ll j = 1; j <= Q; j ++)
                Add( Cod(h,i,j) , Cod(h-1,i,j) , gi());
    for(RG ll i = 1; i <= P; i ++)
        for(RG ll j = 1; j <= Q; j ++)
            Add(Cod(0,i,j),T,INF);
    for(RG ll i = 1; i <= P; i ++)
        for(RG ll j = 1; j <= Q; j ++)
            Add(S,Cod(R,i,j),INF);
    for(RG ll h = 1; h <= R; h ++)
        for(RG ll i = 1; i <= P; i ++)
            for(RG ll j = 1; j <= Q; j ++)
                for(RG ll f = 0; f < 4; f ++){
                    RG int x = mx[f]+i,y = my[f]+j;
                    if(x<1||y<1||x>P||y>Q)continue;
                    if(h-D>=0)Add(Cod(h-D,x,y),Cod(h,i,j),INF);
                    if(h+D<=R)Add(Cod(h,i,j),Cod(h+D,x,y),INF);
                }

    RG ll Ans = Dinic(); printf("%lld",Ans);
    return 0;
}

[HNOI2013]切糕的更多相关文章

  1. BZOJ 3144: [Hnoi2013]切糕

    3144: [Hnoi2013]切糕 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1495  Solved: 819[Submit][Status] ...

  2. bzoj 3144: [Hnoi2013]切糕 最小割

    3144: [Hnoi2013]切糕 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 681  Solved: 375[Submit][Status] ...

  3. BZOJ_3144_[Hnoi2013]切糕_最小割

    BZOJ_3144_[Hnoi2013]切糕_最小割 Description Input 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R ...

  4. bzoj千题计划142:bzoj3144: [Hnoi2013]切糕

    http://www.lydsy.com/JudgeOnline/problem.php?id=3144 如果D=2 ,两个点,高度为4,建图如下 #include<queue> #inc ...

  5. 【BZOJ3144】[HNOI2013]切糕

    [BZOJ3144][HNOI2013]切糕 题面 题目描述 经过千辛万苦小 A 得到了一块切糕,切糕的形状是长方体,小 A 打算拦腰将切糕切成两半分给小 B.出于美观考虑,小 A 希望切面能尽量光滑 ...

  6. 【BZOJ 3144】 3144: [Hnoi2013]切糕 (最小割模型)

    3144: [Hnoi2013]切糕 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1764  Solved: 965 Description Inp ...

  7. BZOJ3144 Hnoi2013 切糕 【网络流】*

    BZOJ3144 Hnoi2013 切糕 Description Input 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q列的 ...

  8. 【BZOJ3144】[Hnoi2013]切糕 最小割

    [BZOJ3144][Hnoi2013]切糕 Description Input 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q ...

  9. 3144: [Hnoi2013]切糕

    3144: [Hnoi2013]切糕 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1526  Solved: 827[Submit][Status] ...

  10. bzoj3144 [HNOI2013]切糕(最小割)

    bzoj3144 [HNOI2013]切糕(最小割) bzoj Luogu 题面描述见上 题解时间 一开始我真就把这玩意所说的切面当成了平面来做的 事实上只是说相邻的切点高度差都不超过 $ d $ 对 ...

随机推荐

  1. SparkSteaming运行流程分析以及CheckPoint操作

    本文主要通过源码来了解SparkStreaming程序从任务生成到任务完成整个执行流程以及中间伴随的checkpoint操作 注:下面源码只贴出跟分析内容有关的代码,其他省略 1 分析流程 应用程序入 ...

  2. python爬虫登录

    python3 urllib.request 网络请求操作 http://www.cnblogs.com/cocoajin/p/3679821.html python实现 爬取twitter用户姓名 ...

  3. CentOS 7 使用iptables防火墙

    # 停止firewalld服务 systemctl stop firewalld systemctl mask firewalld # 安装iptables-services yum install ...

  4. 用node.js搭建本地服务器

    我的第一篇笔记来写写node.js,我对node.js的并不是很了解,基本的项目路径变换还是会的.原先我下载node.js就是我想学vue.js,后来因为工作的繁忙搁浅了我的计划.最近在学习phase ...

  5. C/C++语言简介之发展历史

    C语言之所以命名为C,是因为 C语言源自Ken Thompson发明的B语言,而 B语言则源自BCPL语言. 1967年,剑桥大学的Martin Richards对CPL语言进行了简化,于是产生了BC ...

  6. Ecshop中transport和jquery不兼容的解决方案

    1.修改文件:/js/transport.js,在最底部增加代码 if (Object.prototype.toJSONString){ var oldToJSONString = Object.to ...

  7. React Native填坑之旅 -- 回归小插曲

    回归RN,非常开心啊! 在React Native 0.49.5上开发,直接遇到一个ios模拟器的问题.这个问题很简单就是Bundle URL not present. 在网上找了很多的解决方法,都不 ...

  8. python开发【第一篇】

    内容编码 python解释器在加载.py文件的时候,会对内容进行编码(默认是ascii编码). ASCII 是基于拉丁系统的一套电脑编码系统, 主要用于显示现代英语和其他西欧语言,其最多只能用8位来表 ...

  9. .net core 部署到 iis 步骤及报错解决方法

    我写了一个Asp.net core mvc项目,但是部署在iis发生了502.5的问题一直解决不了. 环境 系统:最强Win10; 工具:轻巧VS Code; 各种百度bing都没有我要的解决方案,说 ...

  10. R+先知︱Facebook大规模时序预测『真』神器——Prophet(遍地代码图)

    经统专业看到预测的packages都是很眼馋的.除了之前的forecast包,现在这个prophet功能也很强大.本packages是由机器之心报道之后,抽空在周末试玩几小时.一些基本介绍可见机器之心 ...