「loj - 3022」「cqoi 2017」老 C 的方块
good题,考虑像 国家集训队 - happiness 一样在棋盘上搞染色,我毛张 @shadowice1987 的图给你看啊

你像这样奇数层以 red -> blue -> green -> yellow 为一个周期,偶数层 yellow -> green -> blue -> red,就会发现给出的形状都包括恰好四种颜色和一条黑线。那现在就好搞了,就是要在每个连通块里面删除至少一种颜色的全部方块(包括黑线),有这样几种选择:全绿 / 全黄 / 全黑线(即破环红或蓝中的一个),像图右侧一样建图就好了。
#include<bits/stdc++.h>
using namespace std;
enum Color { red=1,blue,yellow,green };
const long long INF=0x3f3f3f3f;
template<class Kap> struct Net {
const long long n;
struct Arc {
long long to, rev; Kap cap;
};
vector<long long> lev,iter;
vector<vector<Arc>> e;
std::queue<long long> q;
Net(long long n):n(n),e(n),lev(n),iter(n) {}
void add(long long one,long long ano,Kap cap) {
// printf(" %lld %lld %lld\n",one,ano,cap);
e[one-1].push_back((Arc){ano-1,(long long)(e[ano-1].size())+(one==ano),cap});
e[ano-1].push_back((Arc){one-1,(long long)(e[one-1].size())-1,0});
}
Kap solve(long long s,long long t) { return solve(s-1,t-1,std::numeric_limits<Kap>::max()); }
bool Getlayer(long long s,long long t) {
lev.assign(n,0);
while(q.size()) q.pop();
lev[s]=1;
q.emplace(s);
while(q.size()) {
long long now=q.front();
q.pop();
if(now==t) break;
for(long long i=0; i<(long long)(e[now].size()); ++i) {
long long y=e[now][i].to; Kap cap=e[now][i].cap;
if(!lev[y] && cap) lev[y]=lev[now]+1,q.emplace(y);
}
}
return lev[t];
};
Kap Augment(long long now,Kap up,long long t) {
if(now==t) return up;
Kap rlow=0;
for(long long& i=iter[now]; i<(long long)(e[now].size()); ++i) {
if(!up) break;
long long y=e[now][i].to; Kap& cap=e[now][i].cap;
if(lev[y]==lev[now]+1 && cap) {
Kap f=Augment(y,min(up,cap),t);
if(f<=0) continue;
cap-=f; e[y][e[now][i].rev].cap+=f; up-=f; rlow+=f;
}
}
if(!rlow) lev[now]=n+1;
return rlow;
};
Kap solve(long long s,long long t,const Kap inf) {
lev.assign(n,0); iter.assign(n,0); Kap res=0,tmp;
while (Getlayer(s,t)) {
iter.assign(n, 0);
if((tmp=Augment(s,inf,t))) res+=tmp;
else break;
}
return res;
}
};
long long r,c,n,celx[100100],cely[100100],celw[100100],S,T,co[100100];
map<long long,long long> mp;
bool valid(long long x,long long y) { return x>=1 && x<=r && y>=1 && y<=c; }
long long getid(long long x,long long y) { return 1ll*(x-1)*c+y; }
signed main() {
scanf("%lld %lld %lld",&c,&r,&n);
for(long long i=1; i<=n; ++i) scanf("%lld %lld %lld",&cely[i],&celx[i],&celw[i]),mp[getid(celx[i],cely[i])]=i;
// for(long long i=1; i<=n; ++i) printf(" ---- %lld %lld %lld\n",celx[i],cely[i],celw[i]);
for(long long i=1; i<=n; ++i) {
if(cely[i]%4==0) co[i]=(celx[i]&1)?3:1;
else if(cely[i]%4==1) co[i]=(celx[i]&1)?1:3;
else if(cely[i]%4==2) co[i]=(celx[i]&1)?2:4;
else co[i]=(celx[i]&1)?4:2;
}
// char tmp[5][10]={"tmp","red","blue","yellow","green"};
// for(long long i=1; i<=n; ++i) puts(tmp[co[i]]);
// for(long long i=1; i<=n; ++i) printf(" %lld",co[i]);
// puts("");
// 1 for red, 2 for blue, 3 for yellow, 4 for green
Net<long long> G(n+2); S=n+1; T=n+2;
for(long long i=1; i<=n; ++i) {
if(co[i]==yellow /*yellow*/) {
G.add(S,i,celw[i]);
if(valid(celx[i],cely[i]-1)) {
long long j=mp[getid(celx[i],cely[i]-1)];
if(j && co[j]==red) G.add(i,j,INF);
}
if(valid(celx[i],cely[i]+1)) {
long long j=mp[getid(celx[i],cely[i]+1)];
if(j && co[j]==red) G.add(i,j,INF);
}
// printf(" --- %lld %lld\n",celx[i],cely[i]);
if(valid(celx[i]-1,cely[i])) {
long long j=mp[getid(celx[i]-1,cely[i])];
if(j && co[j]==red) G.add(i,j,INF);
}
if(valid(celx[i]+1,cely[i])) {
long long j=mp[getid(celx[i]+1,cely[i])];
if(j && co[j]==red) G.add(i,j,INF);
}
}
else if(co[i]==green /*green*/) {
G.add(i,T,celw[i]);
if(valid(celx[i],cely[i]-1)) {
long long j=mp[getid(celx[i],cely[i]-1)];
if(j && co[j]==blue) G.add(j,i,INF);
}
if(valid(celx[i],cely[i]+1)) {
long long j=mp[getid(celx[i],cely[i]+1)];
if(j && co[j]==blue) G.add(j,i,INF);
}
if(valid(celx[i]+1,cely[i])) {
long long j=mp[getid(celx[i]+1,cely[i])];
if(j && co[j]==blue) G.add(j,i,INF);
}
if(valid(celx[i]-1,cely[i])) {
long long j=mp[getid(celx[i]-1,cely[i])];
if(j && co[j]==blue) G.add(j,i,INF);
}
}
else if(co[i]==red) {
if(valid(celx[i],cely[i]+1)) {
long long j=mp[getid(celx[i],cely[i]+1)];
// if(celx[i]==1 && cely[i]==1 && j) printf(" -- %lld %lld %lld %lld %lld\n",celx[i],cely[i],celw[i],getid(celx[i],cely[i]),mp[getid(celx[i],cely[i])]);
if(j && co[j]==blue) G.add(i,j,min(celw[i],celw[j]));
}
if(valid(celx[i],cely[i]-1)) {
long long j=mp[getid(celx[i],cely[i]-1)];
// if(celx[i]==1 && cely[i]==1 && j) printf(" -- %lld %lld %lld %lld %lld\n",celx[i],cely[i],celw[i],getid(celx[i],cely[i]),mp[getid(celx[i],cely[i])]);
if(j && co[j]==blue) G.add(i,j,min(celw[i],celw[j]));
}
if(valid(celx[i]+1,cely[i])) {
long long j=mp[getid(celx[i]+1,cely[i])];
// if(celx[i]==1 && cely[i]==1 && j) printf(" -- %lld %lld %lld %lld %lld\n",celx[i],cely[i],celw[i],getid(celx[i],cely[i]),mp[getid(celx[i],cely[i])]);
if(j && co[j]==blue) G.add(i,j,min(celw[i],celw[j]));
}
if(valid(celx[i]-1,cely[i])) {
long long j=mp[getid(celx[i]-1,cely[i])];
// if(celx[i]==1 && cely[i]==1 && j) printf(" -- %lld %lld %lld %lld %lld\n",celx[i],cely[i],celw[i],getid(celx[i],cely[i]),mp[getid(celx[i],cely[i])]);
if(j && co[j]==blue) G.add(i,j,min(celw[i],celw[j]));
}
}
}
printf("%lld\n",G.solve(S,T));
return 0;
}
「loj - 3022」「cqoi 2017」老 C 的方块的更多相关文章
- [LOJ#3022][网络流]「CQOI2017」老 C 的方块
题目传送门 定义有特殊边相邻的格子颜色为黑,否则为白 可以看出,题目给出的限制条件的本质是如果两个小方块所在的格子 \(x\) 和 \(y\) 为两个相邻的黑格,那么 \(x\) 和 \(y\) 之间 ...
- Loj #2331. 「清华集训 2017」某位歌姬的故事
Loj #2331. 「清华集训 2017」某位歌姬的故事 IA 是一名会唱歌的女孩子. IOI2018 就要来了,IA 决定给参赛选手们写一首歌,以表达美好的祝愿.这首歌一共有 \(n\) 个音符, ...
- Loj #2324. 「清华集训 2017」小 Y 和二叉树
Loj #2324. 「清华集训 2017」小 Y 和二叉树 小Y是一个心灵手巧的OIer,她有许多二叉树模型. 小Y的二叉树模型中,每个结点都具有一个编号,小Y把她最喜欢的一个二叉树模型挂在了墙上, ...
- Loj #2321. 「清华集训 2017」无限之环
Loj #2321. 「清华集训 2017」无限之环 曾经有一款流行的游戏,叫做 *Infinity Loop***,先来简单的介绍一下这个游戏: 游戏在一个 \(n \times m\) 的网格状棋 ...
- Loj 2320.「清华集训 2017」生成树计数
Loj 2320.「清华集训 2017」生成树计数 题目描述 在一个 \(s\) 个点的图中,存在 \(s-n\) 条边,使图中形成了 \(n\) 个连通块,第 \(i\) 个连通块中有 \(a_i\ ...
- 【LOJ#6066】「2017 山东一轮集训 Day3」第二题(哈希,二分)
[LOJ#6066]「2017 山东一轮集训 Day3」第二题(哈希,二分) 题面 LOJ 题解 要哈希是很显然的,那么就考虑哈希什么... 要找一个东西可以表示一棵树,所以我们找到了括号序列. 那么 ...
- [LOJ#2330]「清华集训 2017」榕树之心
[LOJ#2330]「清华集训 2017」榕树之心 试题描述 深秋.冷风吹散了最后一丝夏日的暑气,也吹落了榕树脚下灌木丛的叶子.相识数年的Evan和Lyra再次回到了小时候见面的茂盛榕树之下.小溪依旧 ...
- [LOJ#2329]「清华集训 2017」我的生命已如风中残烛
[LOJ#2329]「清华集训 2017」我的生命已如风中残烛 试题描述 九条可怜是一个贪玩的女孩子. 这天她在一堵墙钉了 \(n\) 个钉子,第 \(i\) 个钉子的坐标是 \((x_i,y_i)\ ...
- [LOJ#2328]「清华集训 2017」避难所
[LOJ#2328]「清华集训 2017」避难所 试题描述 "B君啊,你当年的伙伴都不在北京了,为什么你还在北京呢?" "大概是因为出了一些事故吧,否则这道题就不叫避难所 ...
- [LOJ#2327]「清华集训 2017」福若格斯
[LOJ#2327]「清华集训 2017」福若格斯 试题描述 小d是4xx9小游戏高手. 有一天,小d发现了一个很经典的小游戏:跳青蛙. 游戏在一个 \(5\) 个格子的棋盘上进行.在游戏的一开始,最 ...
随机推荐
- SCI 投稿中像素、DPI、图片分辨率的一些知识
最近在学习 Linux 命令行下的 ImageMagick 图像处理,对图像本身的一些概念有点懵,搜集整理了一点资料,仅供自己和大家学习与参考. SCI 期刊对分辨率大多都有一定的要求,例如一段来自 ...
- ResNet模型:在计算机视觉任务中实现深度学习
目录 1. 引言 2. 技术原理及概念 2.1 基本概念解释 2.2 技术原理介绍 3. 实现步骤与流程 3.1 准备工作:环境配置与依赖安装 3.2 核心模块实现 3.3 集成与测试 4. 示例与应 ...
- 性能优化之window.onload
前言 最近在做一些性能优化相关的工作,相信大家在工作过程中也会遇到一些性能优化相关的场景,这对于前端开发者来讲是一项加分技能.为了我们的用户在使用我们的产品时能够有一个非常好的体验,我们需要对页面进行 ...
- BitLocker加密过程中断断电,能否恢复数据?
BitLocker是Windows系统提供的磁盘加密功能,用户自己可以手动开启.在访问受BitLocker保护的磁盘分区时,需要先提供正确的密码.秘钥或是BEK文件.如果使用BitLocker将系统盘 ...
- 《最新出炉》系列初窥篇-Python+Playwright自动化测试-6-元素定位大法-下篇
1.简介 上一篇主要是讲解我们日常工作中在使用Playwright进行元素定位的一些比较常用的定位方法的理论基础知识以及在什么情况下推荐使用.今天这一篇讲解和分享一下,在日常中很少用到或者很少见的定位 ...
- 2023-07-17:给定一个数组arr,长度为n, 再给定一个数字k,表示一定要将arr划分成k个集合, 每个数字只能进一个集合。 返回每个集合内部的平均值都累加起来最小的值。 平均值向下取整。 1
2023-07-17:给定一个数组arr,长度为n, 再给定一个数字k,表示一定要将arr划分成k个集合, 每个数字只能进一个集合. 返回每个集合内部的平均值都累加起来最小的值. 平均值向下取整. 1 ...
- Mariadb取24小时数据--九五小庞
Mariadb是一种常用的关系型数据库管理系统.在进行实时数据处理时,我们常常需要查询最近24小时的数据来进行分析和处理.下面我们将介绍如何使用MySQL查询最近24小时的数据. SELECT * F ...
- HBase Compaction 原理与线上调优实践
作者:vivo 互联网存储技术团队- Hang Zhengbo 本文对 HBase Compaction 的原理.流程以及限流的策略进行了详细的介绍,列举了几个线上进行调优的案例,最后对 Compac ...
- python: ImportError: cannot import name '_unicodefun' from 'click'
报错 报错原因 click模块版本问题 解决方案 指定click版本为8.0.4 参考链接 https://github.com/psf/black/issues/2964
- node: #!/usr/bin/env node
声明 windows中不支持Shebang,它是通过文件的扩展名来确定使用什么解释器来执行脚本 参考链接: https://juejin.cn/post/6844903826344902670