洛谷 P2403 [SDOI2010]所驼门王的宝藏 题解
题目描述




分析
先放一张图便于理解

这一道题如果暴力建图会被卡成\(n^{2}\)
实际上,在我们暴力建图的时候,有很多边都是重复的
假如一行当中有许多横天门的话,我们就不必要把这一行当中的所有点和每一个横天门都连上一条边
因为横天门之间是相互联通的,无论我们走到哪一个横天门,都可以走到同一行的另一个横天门
因此,我们可以先把这些横天门连成一个环,在这些横天门中选取一个点作为代表,连向同一行中不是横天门的点
对于纵寰门也是如此
剩下的任意门直接暴力扫一遍建边即可
代码
#include<bits/stdc++.h>
using namespace std;
const int maxn=2e6+5;
int head[maxn],tot=1;
inline int read(){
int x=0,f=1;
char ch=getchar();
while(ch<'0' || ch>'9'){
if(ch=='-') f=-1;
ch=getchar();
}
while(ch>='0' && ch<='9'){
x=(x<<1)+(x<<3)+(ch^48);
ch=getchar();
}
return x*f;
}
int dx[10]={0,0,1,-1,1,1,-1,-1};
int dy[10]={1,-1,0,0,-1,1,-1,1};
struct asd{
int to,next;
}b[maxn];
void ad(int aa,int bb){
b[tot].to=bb;
b[tot].next=head[aa];
head[aa]=tot++;
}
struct jll{
int jlx,jly,jlb,id;
}jl[maxn];
int n,r,c,nx,ny,nb,rd[maxn];
int dfn[maxn],low[maxn],dfnc,sta[maxn],top,js,shuyu[maxn],siz[maxn];
void tar(int xx){
dfn[xx]=low[xx]=++dfnc;
sta[++top]=xx;
for(int i=head[xx];i!=-1;i=b[i].next){
int u=b[i].to;
if(!dfn[u]){
tar(u);
low[xx]=min(low[u],low[xx]);
} else if(!shuyu[u]){
low[xx]=min(low[xx],dfn[u]);
}
}
if(dfn[xx]==low[xx]){
js++;
while(1){
int now=sta[top--];
shuyu[now]=js;
siz[js]++;
if(now==xx) break;
}
}
}
map<pair<int,int>,bool> mp;
struct asd2{
int to,next,val;
}b2[maxn];
int h2[maxn],t2=1;
void ad2(int aa,int bb,int cc){
b2[t2].to=bb;
b2[t2].next=h2[aa];
b2[t2].val=cc;
h2[aa]=t2++;
}
int f[maxn],ans=0;
void tp(){
queue<int> q;
q.push(0);
while(!q.empty()){
int now=q.front();
q.pop();
for(int i=h2[now];i!=-1;i=b2[i].next){
int u=b2[i].to;
rd[u]--;
f[u]=max(f[u],f[now]+b2[i].val);
if(rd[u]==0) q.push(u);
}
}
}
bool cmplh(jll aa,jll bb){
if(aa.jlb==bb.jlb && aa.jlx==bb.jlx) return aa.jly<bb.jly;
if(aa.jlb==bb.jlb) return aa.jlx<bb.jlx;
return aa.jlb<bb.jlb;
}
bool cmpll(jll aa,jll bb){
if(aa.jlb==bb.jlb && aa.jly==bb.jly) return aa.jlx<bb.jlx;
if(aa.jlb==bb.jlb) return aa.jly<bb.jly;
if(aa.jlb==2) return 1;
return 0;
}
bool cmpry(jll aa,jll bb){
return aa.jlb>bb.jlb;
}
map<pair<int,int>,int> mpp;
int htm[maxn],ztm[maxn];
int main(){
memset(head,-1,sizeof(head));
memset(h2,-1,sizeof(h2));
n=read(),r=read(),c=read();
for(int i=1;i<=n;i++){
jl[i].jlx=read();
jl[i].jly=read();
jl[i].jlb=read();
jl[i].id=i;
mpp[make_pair(jl[i].jlx,jl[i].jly)]=jl[i].id;
}
sort(jl+1,jl+1+n,cmplh);
for(int i=1;i<=n;i++){
if(jl[i].jlb!=1) break;
int ks=jl[i].id;
while(jl[i].jlx==jl[i+1].jlx && jl[i+1].jlb==1){
ad(jl[i].id,jl[i+1].id);
i++;
}
ad(jl[i].id,ks);
htm[jl[i].jlx]=jl[i].id;
}
sort(jl+1,jl+1+n,cmpll);
for(int i=1;i<=n;i++){
if(jl[i].jlb!=2) break;
int ks=jl[i].id;
while(jl[i].jly==jl[i+1].jly && jl[i+1].jlb==2){
ad(jl[i].id,jl[i+1].id);
i++;
}
ad(jl[i].id,ks);
ztm[jl[i].jly]=jl[i].id;
}
sort(jl+1,jl+1+n,cmpry);
for(int i=1;i<=n;i++){
if(jl[i].jlb!=3) break;
int nx=jl[i].jlx,ny=jl[i].jly;
for(int j=0;j<8;j++){
int mx=nx+dx[j];
int my=ny+dy[j];
if(mpp[make_pair(mx,my)]){
ad(jl[i].id,mpp[make_pair(mx,my)]);
}
}
}
for(int i=1;i<=n;i++){
if(jl[i].jlb==1) continue;
int ks=jl[i].id;
if(htm[jl[i].jlx]!=0) ad(htm[jl[i].jlx],jl[i].id);
}
for(int i=1;i<=n;i++){
if(jl[i].jlb==2) continue;
int ks=jl[i].id;
if(ztm[jl[i].jly]!=0) ad(ztm[jl[i].jly],jl[i].id);
}
for(int i=1;i<=n;i++){
if(!dfn[i]) tar(i);
}
for(int i=1;i<=n;i++){
for(int j=head[i];j!=-1;j=b[j].next){
int u=b[j].to;
if(shuyu[i]!=shuyu[u] && mp[make_pair(shuyu[i],shuyu[u])]==0){
ad2(shuyu[i],shuyu[u],siz[shuyu[u]]);
rd[shuyu[u]]++;
mp[make_pair(shuyu[i],shuyu[u])]=1;
}
}
}
for(int i=1;i<=js;i++){
if(rd[i]==0){
ad2(0,i,siz[i]);
rd[i]++;
}
}
tp();
for(int i=1;i<=js;i++){
ans=max(ans,f[i]);
}
printf("%d\n",ans);
return 0;
}
洛谷 P2403 [SDOI2010]所驼门王的宝藏 题解的更多相关文章
- 洛谷 2403 [SDOI2010] 所驼门王的宝藏
题目描述 在宽广的非洲荒漠中,生活着一群勤劳勇敢的羊驼家族.被族人恭称为“先知”的Alpaca L. Sotomon是这个家族的领袖,外人也称其为“所驼门王”.所驼门王毕生致力于维护家族的安定与和谐, ...
- 洛咕 P2403 [SDOI2010]所驼门王的宝藏
简单tarjan. 一行的横天门如果暴力连边会被卡成平方,所以只要相邻两个横天门连双向边,再随便选一个横天门向整行连边即可.纵寰门同理.ziyou门直接map暴力连边. 然后tarjan直接dp. / ...
- Luogu P2403 [SDOI2010]所驼门王的宝藏
比较显然的缩点+拓扑排序题,只不过要建虚点优化建边. 首先我们发现在一个SCC里的点都是可以一起对答案产生贡献的,因此先缩成DAG,然后拓扑找最长链. 但是我们发现这题最坏情况下边数会达到恐怖的\(O ...
- BZOJ 1924 && Luogu P2403 [SDOI2010]所驼门王的宝藏 恶心建图+缩点DP
记住:map一定要这么用: if(mp[x[i]+dx[j]].find(y[i]+dy[j])!=mp[x[i]+dx[j]].end()) add(i,mp[x[i]+dx[j]][y[i]+dy ...
- [bzoj1924]P2403 [SDOI2010]所驼门王的宝藏
tarjan+DAG 上的 dp 难点在于建图和连边,其实也不难,就是细节挺恶心 我和正解对拍拍出来 3 个错误... 传送门:luogu bzoj 题目描述 有座宫殿呈矩阵状,由 \(R\times ...
- [BZOJ 1924][Sdoi2010]所驼门王的宝藏
1924: [Sdoi2010]所驼门王的宝藏 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 1285 Solved: 574[Submit][Sta ...
- 【题解】SDOI2010所驼门王的宝藏(强连通分量+优化建图)
[题解]SDOI2010所驼门王的宝藏(强连通分量+优化建图) 最开始我想写线段树优化建图的说,数据结构学傻了233 虽然矩阵很大,但是没什么用,真正有用的是那些关键点 考虑关键点的类型: 横走型 竖 ...
- [SDOI2010]所驼门王的宝藏
题目描述 在宽广的非洲荒漠中,生活着一群勤劳勇敢的羊驼家族.被族人恭称为"先知"的Alpaca L. Sotomon是这个家族的领袖,外人也称其为"所驼门王". ...
- [LuoguP2403][SDOI2010]所驼门王的宝藏
题目描述 在宽广的非洲荒漠中,生活着一群勤劳勇敢的羊驼家族.被族人恭称为"先知"的Alpaca L. Sotomon是这个家族的领袖,外人也称其为"所驼门王". ...
随机推荐
- Validate日期校验
public class Validate { private static Regex RegNumber = new Regex("^[0-9]+$"); private st ...
- EDM邮件制作
EDM营销(Email Direct Marketing)也叫:Email营销.电子邮件营销.是指企业向目标客户发送EDM邮件,建立同目标顾客的沟通渠道,向其直接传达相关信息,用来促进销售的一种营销手 ...
- 前端进阶笔记之核心基础知识---那些HTML标签你熟悉吗?
目录 1.交互实现 1.1 meta标签:自动刷新/跳转 1.2 title标签:消息提醒 2.性能优化 2.1 script标签:调整加载顺序提升渲染速度 2.2 link标签:通过预处理提升渲染速 ...
- win10 64位 MySQL 8.0 下载与安装
免安装版(超级棒的教程): 安装只需 Download .zip压缩文件 卸载只需 Delete 解压文件即可 https://blog.csdn.net/hzxOnlineOk/article/de ...
- Spring 获取单例流程(二)
读完这篇文章你将会收获到 Spring 中 prototype 类型的 bean 如何做循环依赖检测 Spring 中 singleton 类型的 bean 如何做循环依赖检测 前言 继上一篇文章 S ...
- 新技术新框架不断涌现,目前学习web前端开发都要掌握什么?
web前端开发由网页制作演变而来,随着web2.0的发展,网页不再只是承载单一的文字和图片,各种丰富媒体让网页的内容更加生动,网页上软件化的交互形式为用户提供了更好的使用体验,这些都是基于前端技术实现 ...
- 【SpringCloud】Gateway 配置全局过滤器获取请求参数和响应值
[SpringCloud]Gateway 配置全局过滤器获取请求参数和响应值 实现Ordered接口getOrder()方法,数值越小越靠前执行,记得这一点就OK了. 获取请求参数RequestBod ...
- 常用API - 包装类、System类
包装类 概述 Java提供了两个类型系统,基本类型与引用类型,使用基本类型在于效率. 然而很多情况,会创建对象使用,因为对象可以做更多的功能. 如果想要我们的基本类型像对象一样操作,就可以使用基本类型 ...
- sun.reflect.generics.reflectiveObjects.TypeVariableImpl cannot be cast to java.lang.Class
1.首先,问题出现的点是在泛型 我出现问题的原因是,和泛型有关系,要调整泛型 2.我把问题出现的过程描述一哈子 1.基础类 @tk.mybatis.mapper.annotation.Register ...
- Buy A Ticket(图论)
Buy A Ticket 题目大意 每个点有一个点权,每个边有一个边权,求对于每个点u的\(min(2*d(u,v)+val[v])\)(v可以等于u) solution 想到了之前的虚点,方便统计终 ...