题目链接

(Luogu) https://www.luogu.org/problem/P3756
(BZOJ) http://lydsy.com/JudgeOnline/problem.php?id=4823

题解

有点神仙的最小割题。
考虑题目里的图形,如果我们用四种颜色对棋盘进行染色,奇数行依次染\(0,1,2,3,0,1,2,3...\), 偶数行依次染\(3,2,1,0,3,2,1,0...\)则条件可以转化为不能出现相连的\(4\)个颜色互不相同的块。
那么可以建一个四层的图,对于每条两侧都有关键点的特殊边,按照\(S\rightarrow 3\rightarrow 0\rightarrow 1\rightarrow 2\rightarrow T\)的顺序连边,其中\(S\rightarrow 3\)连\(3\)色点的点权,\(0\rightarrow 1\)连两个关键点权值的最小值,\(2\rightarrow T\)连\(2\)色点的点权。不出现相连的四个颜色互不相同的块等价于不存在从\(S\)到\(T\)的路径。
然后跑最小割即可。
因为是分层图,所以dinic跑得很快(复杂度应该是\(O(n\sqrt n)\)),可以通过此题。

代码

#include<bits/stdc++.h>
#define llong long long
using namespace std;const int INF = 1e9;
namespace NetFlow
{const int N = 1e5+2;const int M = 8e5;struct Edge{int v,w,nxt,rev;} e[(M<<1)+3];int fe[N+3];int te[N+3];int dep[N+3];int que[N+3];int n,en,s,t;void addedge(int u,int v,int w){
//      printf("addedge %d %d %d\n",u,v,w);en++; e[en].v = v; e[en].w = w;e[en].nxt = fe[u]; fe[u] = en; e[en].rev = en+1;en++; e[en].v = u; e[en].w = 0;e[en].nxt = fe[v]; fe[v] = en; e[en].rev = en-1;}bool bfs(){for(int i=1; i<=n; i++) dep[i] = 0;int head = 1,tail = 1; que[1] = s; dep[s] = 1;while(head<=tail){int u = que[head]; head++;for(int i=fe[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0 && dep[v]==0){dep[v] = dep[u]+1;if(v==t)return true;tail++; que[tail] = v;}}}return false;}int dfs(int u,int cur){if(u==t||cur==0) {return cur;}int rst = cur;for(int &i=te[u]; i; i=e[i].nxt){int v = e[i].v;if(e[i].w>0 && rst>0 && dep[v]==dep[u]+1){int flow = dfs(v,min(rst,e[i].w));if(flow>0){e[i].w -= flow; rst -= flow;e[e[i].rev].w += flow;if(rst==0) {return cur;}}}}if(rst==cur) {dep[u] = -2;}return cur-rst;}int dinic(int _n,int _s,int _t){n = _n,s = _s,t = _t;int ret = 0;while(bfs()){for(int i=1; i<=n; i++) te[i] = fe[i];memcpy(te,fe,sizeof(int)*(n+1));ret += dfs(s,INF);}return ret;}
}
using NetFlow::addedge;
using NetFlow::dinic;const int N = 1e5;
struct Point
{int x,y,w;
} a[N+3];
map<int,int> mp[N+3];
int id[N+3],clr[N+3];
int n,nx,ny;int getclr(int x,int y)
{if(y&1) {return (x-1)&3;}else {return 3-((x-1)&3);}
}int main()
{scanf("%d%d%d",&nx,&ny,&n);for(int i=1; i<=n; i++){scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].w);mp[a[i].x][a[i].y] = i;}for(int i=1; i<=n; i++){int x = a[i].x,y = a[i].y,clr = getclr(x,y);if(((x+(y<<1))&3)==3 && mp[x+1].count(y)){int j = mp[x+1][y],w = min(a[i].w,a[j].w);if(clr==0){int k = mp[x-1][y]; if(k) {addedge(k+2,i+2,INF);}k = mp[x][y-1]; if(k) {addedge(k+2,i+2,INF);}k = mp[x][y+1]; if(k) {addedge(k+2,i+2,INF);}k = mp[x+2][y]; if(k) {addedge(j+2,k+2,INF);}k = mp[x+1][y+1]; if(k) {addedge(j+2,k+2,INF);}k = mp[x+1][y-1]; if(k) {addedge(j+2,k+2,INF);}addedge(i+2,j+2,w);}else if(clr==1){int k = mp[x+2][y]; if(k) {addedge(k+2,j+2,INF);}k = mp[x+1][y+1]; if(k) {addedge(k+2,j+2,INF);}k = mp[x+1][y-1]; if(k) {addedge(k+2,j+2,INF);}k = mp[x-1][y]; if(k) {addedge(i+2,k+2,INF);}k = mp[x][y-1]; if(k) {addedge(i+2,k+2,INF);}k = mp[x][y+1]; if(k) {addedge(i+2,k+2,INF);}addedge(j+2,i+2,w);}}else if(clr==3){addedge(1,i+2,a[i].w);}else if(clr==2){addedge(i+2,2,a[i].w);}}int ans = dinic(n+2,1,2);printf("%d\n",ans);return 0;
}

BZOJ 4823 Luogu P3756 [CQOI2017]老C的方块 (网络流、最小割)相关推荐

  1. [bzoj4823][洛谷P3756][Cqoi2017]老C的方块

    Description 老 C 是个程序员. 作为一个懒惰的程序员,老 C 经常在电脑上玩方块游戏消磨时间.游戏被限定在一个由小方格排成的R行C列网格上 ,如果两个小方格有公共的边,就称它们是相邻的, ...

  2. BZOJ 3218 UOJ #77 A+B Problem (主席树、最小割)

    BZOJ 3218 UOJ #77 A+B Problem (主席树.最小割) 大名鼎鼎的A+B Problem, 主席树优化最小割-- 调题死活调不对,一怒之下改了一种写法交上去A了,但是改写法之后 ...

  3. BZOJ 1266: [AHOI2006]上学路线route Floyd算法,网络最小割

    Description 可可和卡卡家住合肥市的东郊,每天上学他们都要转车多次才能到达市区西端的学校.直到有一天他们两人参加了学校的信息学奥林匹克竞赛小组才发现每天上学的乘车路线不一定是最优的. 可可: ...

  4. BZOJ 4814 Luogu P3699 [CQOI2017]小Q的草稿 (计算几何、扫描线、set)

    题目链接 (BZOJ) http://lydsy.com/JudgeOnline/problem.php?id=4814 (Luogu) https://www.luogu.org/problem/P ...

  5. 题解 [CQOI2017] 老 C 的方块

    这题我们教练出的. Sto nodgd Orz 一般来说,看到网格题,想到网络流.看到要炸点,考虑染色,这道题的四个形状都是四个格子,考虑染成四色(图片来自 shadowice1984 的题解): 那 ...

  6. BZOJ 1001: [BeiJing2006]狼抓兔子【最大流/SPFA+最小割,多解】

    1001: [BeiJing2006]狼抓兔子 Time Limit: 15 Sec  Memory Limit: 162 MB Submit: 23822  Solved: 6012 [Submit ...

  7. BZOJ 2400(网络流最小割)

    思路: 首先比较显然能够想到二进制拆分 每一位的贡献是独立的 然后可以用最小割解决 S->i 表示这一个位置是0 inf i-T 表示为1 inf 然后所有的边保留 1 这样只要最后再找一遍t集 ...

  8. luogu P3410 拍照(最大权闭合图转最小割)

    luogu P3410 拍照 最大权闭合图转最小割 要得到最大收益,我们可以用总可能收益减去最小花费,也就是最小割. #include<cstdio> #include<cstrin ...

  9. BZOJ 3894 Luogu P4313 文理分科 (最小割)

    题目链接: (bzoj) https://www.lydsy.com/JudgeOnline/problem.php?id=3894 (luogu) https://www.luogu.org/pro ...

最新文章

  1. ping -c3 baidu.com  ping过去是这样,代表网络畅通
  2. 推出第一个免费工具CCT
  3. 用番茄工作法提升工作效率 (三)工作任务的管理(系列完结篇)
  4. 基于深度学习的交通标识别算法对比研究-TensorFlow2实现
  5. 向周鸿祎的360安全浏览器学互联网产品运营和推广
  6. 现代IM系统中消息推送和存储架构的实现
  7. 纷享销客完成新一轮数亿元融资,持续领跑中国CRM产业发展
  8. CV Code | 计算机视觉开源周报20190904期
  9. srpm包的编译方式
  10. 当 AI 遇见经典,科大讯飞发布两款智能笔记本新品!
  11. Flume OG 与 Flume NG 的对比
  12. PMP不报培训班的通过率高吗?
  13. 抖音最近流行的爱心代码(C语言版)
  14. VB2010中的MediaPlayer控件在哪?
  15. 支持bt,种子,torrent的离线下载网页版工具!
  16. 玩和平精英跟刺激战场国际服都被吊打?网友:你还可以玩荒野行动
  17. 基于MATLAB车牌识别算法实现 GUI界面
  18. CVE-2017-0143(远程溢出)漏洞复现
  19. java ajax serialize,jQuery使用serialize(),serializeArray()方法取得表单数据
  20. cocos creater 鸿蒙 音频卡死 播放失败 不回调

热门文章

  1. 学长毕业日记 :本科毕业论文写成博士论文的神操作20170324
  2. 使用wdcp面板安装感恩教师节wordpress网站
  3. 寻找免费的阿里云云盾隐秘购买入口,申请并下载ssl证书(https证书)的详细步骤
  4. c4d流体插件_【C4D】流体插件详细讲解
  5. Go进阶(9): For Range 性能研究
  6. #中调用委托的简单方法
  7. JavaScript不区分 '
  8. wireshark抓包详解
  9. BugkuCTF-Misc:多彩
  10. 链表之CIRCLEQ