bzoj4823: [Cqoi2017]老C的方块(最小割)
4823: [Cqoi2017]老C的方块
题目:传送门
题解:
毒瘤题ORZ....
太菜了看出来是最小割啥边都不会建...狂%大佬强强强

黑白染色?不!是四个色一起染,四层图跑最小割。。。
很惊奇的发现染完色之后只要是不喜欢的图形都一定可以由黄-->黑-->红-->绿 组成
那就很nice啦...兴高采烈的去敲代码...结果10^5*10^5???搞毛线...太弱了ORZ,又看了一波大佬的操作,用map存!
woc...不谈了不谈了...撸撸撸(分情况分到想屎...虽然不多)
注意一下...黑到红连边的时候是不可以连inf的...然而我傻逼逼的打了...改成min(w[黑],w[红])...
代码:
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<map>
#define inf 999999999
#define qread(x) x=read()
using namespace std;
typedef long long LL;
inline LL read()
{
LL x=,f=;char ch;
while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return f*x;
}
struct node
{
int x,y,c,next,other;
}a[];int len,last[];
int n,m,T,st,ed;
void ins(int x,int y,int c)
{
int k1,k2;
k1=++len;
a[len].x=x;a[len].y=y;a[len].c=c;
a[len].next=last[x];last[x]=len; k2=++len;
a[len].x=y;a[len].y=x;a[len].c=;
a[len].next=last[y];last[y]=len; a[k1].other=k2;
a[k2].other=k1;
}
int head,tail;
int list[],h[];
bool bt_h()
{
memset(h,,sizeof(h));h[st]=;
list[]=st;head=;tail=;
while(head!=tail)
{
int x=list[head];
for(int k=last[x];k;k=a[k].next)
{
int y=a[k].y;
if(!h[y] && a[k].c)
{
h[y]=h[x]+;
list[tail++]=y;
}
}
head++;
}
if(h[ed])return true;
return false;
}
int find_flow(int x,int flow)
{
int s=,t;
if(x==ed)return flow;
for(int k=last[x];k;k=a[k].next)
{
int y=a[k].y;
if(h[y]==h[x]+ && a[k].c && s<flow)
{
s+=t=find_flow(y,min(a[k].c,flow-s));
a[k].c-=t;a[a[k].other].c+=t;
}
}
if(!s)h[x]=;
return s;
}
int x[],y[],w[];//第x列,第y行,金币数
map<pair<int,int>,int>id;
int main()
{
len=;memset(last,,sizeof(last));
memset(w,,sizeof(w));
qread(n);qread(m);qread(T);st=T+;ed=st+;
for(int i=;i<=T;i++){qread(x[i]);qread(y[i]);qread(w[i]);id[make_pair(x[i],y[i])]=i;}
//黄-->黑-->红-->绿
for(int i=;i<=T;i++)
{
if(x[i]%==)//黑或黄
{
if(y[i]%==)ins(st,i,w[i]);//黄
else//黑
{
if(id[make_pair(x[i]+,y[i])])ins(id[make_pair(x[i]+,y[i])],i,inf);
if(id[make_pair(x[i],y[i]+)])ins(id[make_pair(x[i],y[i]+)],i,inf);
if(id[make_pair(x[i],y[i]-)])ins(id[make_pair(x[i],y[i]-)],i,inf);
}
}
if(x[i]%==)//黑或黄
{
if(y[i]%==)ins(st,i,w[i]);//黄
else//黑
{
//黑-->黄
if(id[make_pair(x[i],y[i]-)])ins(id[make_pair(x[i],y[i]-)],i,inf);
if(id[make_pair(x[i],y[i]+)])ins(id[make_pair(x[i],y[i]+)],i,inf);
if(id[make_pair(x[i]-,y[i])])ins(id[make_pair(x[i]-,y[i])],i,inf); //黑-->红(计算w)
if(id[make_pair(x[i]+,y[i])])
ins(i,id[make_pair(x[i]+,y[i])],min(w[i],w[id[make_pair(x[i]+,y[i])]]));
}
}
if(x[i]%==)//红或绿
{
if(y[i]%==)//红
{
if(id[make_pair(x[i],y[i]-)])ins(i,id[make_pair(x[i],y[i]-)],inf);
if(id[make_pair(x[i],y[i]+)])ins(i,id[make_pair(x[i],y[i]+)],inf);
if(id[make_pair(x[i]+,y[i])])ins(i,id[make_pair(x[i]+,y[i])],inf);
}
else ins(i,ed,w[i]);//绿
}
if(x[i]%==)//红或绿
{
if(y[i]%==)//红
{
//红-->绿
if(id[make_pair(x[i],y[i]-)])ins(i,id[make_pair(x[i],y[i]-)],inf);
if(id[make_pair(x[i],y[i]+)])ins(i,id[make_pair(x[i],y[i]+)],inf);
if(id[make_pair(x[i]-,y[i])])ins(i,id[make_pair(x[i]-,y[i])],inf); //黑-->红
if(id[make_pair(x[i]+,y[i])])
ins(id[make_pair(x[i]+,y[i])],i,min(w[i],w[id[make_pair(x[i]+,y[i])]]));
}
else ins(i,ed,w[i]);//绿
}
}
int ans=;
while(bt_h())ans+=find_flow(st,inf);
printf("%d\n",ans);
return ;
}
bzoj4823: [Cqoi2017]老C的方块(最小割)的更多相关文章
- bzoj 4823: [Cqoi2017]老C的方块 [最小割]
4823: [Cqoi2017]老C的方块 题意: 鬼畜方块游戏不解释... 有些特殊边,有些四个方块组成的图形,方块有代价,删掉一些方块使得没有图形,最小化代价. 比较明显的最小割,一个图形中必须删 ...
- BZOJ4823 CQOI2017老C的方块(最小割)
如果将其转化为一个更一般的问题即二分图带权最小单边点覆盖(最小控制集)感觉是非常npc的.考虑原题给的一大堆东西究竟有什么奇怪的性质. 容易发现如果与特殊边相邻的两格子都放了方块,并且这两个格子都各有 ...
- BZOJ4823 [Cqoi2017]老C的方块 【最小割】
题目 老C是个程序员. 作为一个懒惰的程序员,老C经常在电脑上玩方块游戏消磨时间.游戏被限定在一个由小方格排成的R行C列网格上,如果两个小方格有公共的边,就称它们是相邻的,而且有些相邻的小方格之间的公 ...
- [bzoj4823][Cqoi2017]老C的方块
来自FallDream的博客,未经允许,请勿转载,谢谢. 挺有意思的一道题.... 看完题面比较明确是最小割,考虑怎么建图 想了比较久 突破口应该是题目中那张奇怪的图 观察这个奇怪的图和方块,很容易发 ...
- bzoj千题计划300:bzoj4823: [Cqoi2017]老C的方块
http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...
- bzoj 4823 & 洛谷 P3756 老C的方块 —— 最小割
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4823 https://www.luogu.org/problemnew/show/P3756 ...
- 【BZOJ4823】[CQOI2017]老C的方块(网络流)
[BZOJ4823][CQOI2017]老C的方块(网络流) 题面 BZOJ 题解 首先还是给棋盘进行黑白染色,然后对于特殊边左右两侧的格子单独拎出来考虑. 为了和其他格子区分,我们把两侧的这两个格子 ...
- 【洛谷P3756】[CQOI2017]老C的方块(最小割)
洛谷 题意: 给出一个网格图类似于这样: 现在给出一个\(n*m\)大小的网格,之后会给出一些点,若某些点相连形成了如下的几个图案,那么就是不好的. 现在可以删去一些点,但删除每个点都有一些代价,问最 ...
- BZOJ 4823 Luogu P3756 [CQOI2017]老C的方块 (网络流、最小割)
题目链接 (Luogu) https://www.luogu.org/problem/P3756 (BZOJ) http://lydsy.com/JudgeOnline/problem.php?id= ...
随机推荐
- UITableView属性 自己定义UITableViewCell
UITableView的属性全齐.供大家參考 附:http://www.bubuko.com/infodetail-561085.html //曾经在使用UITableView的时候,总是在cell上 ...
- 求区间连续不超过K段的最大和--线段树+大量代码
题目描述: 这是一道数据结构题. 我们拥有一个长度为n的数组a[i]. 我们有m次操作.操作有两种类型: 0 i val:表示我们要把a[i]修改为val; 1 l r k:表示我们要求出区间[l,r ...
- ROS-Gazebo文件标签解读
前言:Gazebo是一个三维机器人仿真器,它是独立的软件,支持ROS. 标签 功能 <gazebo> 设置Gazebo仿真的参数 <mu1>, <mu2> 设置摩擦 ...
- C# 读取硬盘信息 ManagementClass类
一.在很多情况下,你可能都需要得到微机的硬件信息.需要加上下面的这句话: using System.Management; 获取硬件信息,需先知道硬件参数信息: Win32_Processor, // ...
- SQL学习——基础语句(1)
简序 1.SQL,指结构化查询语言,全称是 Structured Query Language. 2.SQL 让您可以访问和处理数据库. 3.SQL 是一种 ANSI(American Nationa ...
- C#数组大小分析(附测试过程中想起的debug和release区别)
C#数组的理论最大长度到底是多少呢?曾经一度问过度娘,谷歌,貌似都没有得出一个比较准确的答案,无外乎是什么Int32的最大值啊什么的,今天终于决定写个软件来自己测试一下,在几台不同的电脑里面实际测试看 ...
- UNP学习笔记1——基本TCP套接字编程
1 套接字地址结构 大多数套接字函数都需要一个指向套接字地址结构的指针作为参数.每个协议族都定义了自己的套接字结构.这些套接字的结构以sockaddr_开头,以每个协议族唯一的后缀名结尾. 1.1 I ...
- GCC中的弱符号与强符号
GCC中的弱符号与强符号 我们经常在编程中碰到一种情况叫符号重复定义.多个目标文件中含有相同名字全局符号的定义,那么这些目标文件链接的时候将会出现符号重复定义的错误.比如我们在目标文件A和目标文件B都 ...
- 深入分析C++虚函数表
C++中的虚函数(Virtual Function)是用来实现动态多态性的,指的是当基类指针指向其派生类实例时,可以用基类指针调用派生类中的成员函数.如果基类指针指向不同的派生类,则它调用同一个函数就 ...
- ZBrush模型的细分
在ZBrush®中对模型进行雕刻时,随着细节越来越丰富,原有的面数已经不能满足我们对细节的要求,为了得到更多的细节,我们就必须增加模型的面数,让更多的面来支持我们进行雕刻,如下图(左)和下图(右)所示 ...