ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树,倍增lca)
https://nanti.jisuanke.com/t/31462
要求在一个矩形中任意选两个点都有唯一的通路,所以不会建多余的墙。
要求满足上述情况下,建墙的费用最小。理解题意后容易想到首先假设全部墙都建起来,然后拆掉费用最大的边使图成为一棵树,就是求一颗最大生成树
求出最大生成树后,求任意两点的距离,直接用lca就可以
思路
#include<bits/stdc++.h>
#define M 300005
#define pb push_back
using namespace std;
struct E{
int u,v,w;
E(int w,int u,int v):w(w),u(u),v(v){}
bool operator<(const E& rhp)const{
return w>rhp.w;
}
};
vector<E>e;
int fa[M];int fin(int u){return fa[u]==u?u:fa[u]=fin(fa[u]);}
int pr[M][30],d[M],n,m,i,j,a,b,u,v,x,y,x1,x2,Y1,y2,LCA,q;
char s[10];
vector<int>g[M];
void dfs(int u,int fa){
pr[u][0]=fa;
for(int i=1;i<=19;i++)pr[u][i]=pr[pr[u][i-1]][i-1];
for(int i=0;i<g[u].size();i++){
int v=g[u][i];if(v==fa)continue;
d[v]=d[u]+1;
dfs(v,u);
}
}
int lca(int u,int v){
if(d[u]<d[v])swap(u,v);
int dep=d[u]-d[v];
for(int i=19;i>=0;i--){
if(dep&(1<<i)){
dep^=(1<<i);
u=pr[u][i];
}
}
if(u==v)return u;
for(int i=19;i>=0;i--){
if(pr[u][i]!=pr[v][i]){
u=pr[u][i];v=pr[v][i];
}
}
return pr[u][0];
}
int main(){
scanf("%d%d",&n,&m);
for(i=1;i<=n*m+m;i++)fa[i]=i;
for(i=1;i<=n;i++){
for(j=1;j<=m;j++){
scanf("%s %d %s %d",s,&a,s,&b);
if(i<n){
e.pb(E(a,i*m+j,(i+1)*m+j));
}
if(j<m){
e.pb(E(b,i*m+j,i*m+j+1));
}
}
}
sort(e.begin(),e.end());
for(i=0;i<e.size();i++){
u=e[i].u;v=e[i].v;
x=fin(u);y=fin(v);
if(x!=y){
fa[x]=y;
g[u].pb(v);g[v].pb(u);
}
}
dfs(1*m+1,0);
scanf("%d",&q);
while(q--){
scanf("%d%d%d%d",&x1,&Y1,&x2,&y2);
u=x1*m+Y1;v=x2*m+y2;
LCA=lca(u,v);
printf("%d\n",d[u]+d[v]-2*d[LCA]);
}
}
ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树,倍增lca)的更多相关文章
- ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer (最大生成树+LCA求节点距离)
ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer J. Maze Designer After the long vacation, the maze designer ...
- ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer 最大生成树 lca
大概就是要每两个点 只能有一条路径,并且约束,最短的边用来砌墙,那么反之的意思就是最大的边用来穿过 故最大生成树 生成以后 再用lca计算树上两点间的距离 (当然防止生成树是一条链,可以用树的重心作为 ...
- ACM-ICPC 2018 徐州赛区网络预赛 J Maze Designer(最大生成树+LCA)
https://nanti.jisuanke.com/t/31462 题意 一个N*M的矩形,每个格点到其邻近点的边有其权值,需要构建出一个迷宫,使得构建迷宫的边权之和最小,之后Q次查询,每次给出两点 ...
- ACM-ICPC 2018 徐州赛区网络预赛 J. Maze Designer
传送门:https://nanti.jisuanke.com/t/31462 本题是一个树上的问题:结点间路径问题. 给定一个有N×M个结点的网格,并给出结点间建立墙(即拆除边)的代价.花费最小的代价 ...
- ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心)
ACM-ICPC 2018 徐州赛区网络预赛 G. Trace (思维,贪心) Trace 问答问题反馈 只看题面 35.78% 1000ms 262144K There's a beach in t ...
- 计蒜客 1460.Ryuji doesn't want to study-树状数组 or 线段树 (ACM-ICPC 2018 徐州赛区网络预赛 H)
H.Ryuji doesn't want to study 27.34% 1000ms 262144K Ryuji is not a good student, and he doesn't wa ...
- ACM-ICPC 2018 徐州赛区网络预赛 B(dp || 博弈(未完成)
传送门 题面: In a world where ordinary people cannot reach, a boy named "Koutarou" and a girl n ...
- ACM-ICPC 2018 徐州赛区网络预赛 B. BE, GE or NE
In a world where ordinary people cannot reach, a boy named "Koutarou" and a girl named &qu ...
- ACM-ICPC 2018 徐州赛区网络预赛 F. Features Track
262144K Morgana is learning computer vision, and he likes cats, too. One day he wants to find the ...
随机推荐
- [剑指Offer]22-链表中倒数第k个结点
题目链接 https://www.nowcoder.com/practice/529d3ae5a407492994ad2a246518148a?tpId=13&tqId=11167&t ...
- java常量类编译问题
常量类编译后并不在.class文件中呈现,取而代之的是各个具体的常量.例如: 编译前:(Constant.OPTIONSRADIO常量值为1) 编译后: 应用场景 1,项目编译后发布项目前可以删除常量 ...
- 使用python语言计算n的阶乘
计算“1x2x3x4” def factorial(n): result = n ,n): result *= i return resultdef main(): print factorial(4 ...
- docker-ce-17.09 数据卷和数据卷容器
docker容器中管理数据两种方式:1.数据卷(Data Volumes)2.数据卷容器(Data Volume Dontainers) 一.数据卷特性:1.数据卷可以在容器之间共享和重用2.对数据卷 ...
- go语言net包rpc远程调用的使用
一.基于http的RPC 服务端: package main; import ( "net/rpc" "net/http" "log" ) ...
- 【gRPC使用问题2】按照问题1操作生成出来的代码,import的proto内定义的message未生成出来
1.问题 其实元数据proto里是有定义message,但是 这个message的定义是在另一个 proto文件内,被 api.proto导入,事实上 我是对 api.proto 进行命令行生成代码的 ...
- 更换Grade源为阿里云解决下载慢问题
作为程序员,即写的了代码也得翻得上围墙. 现在包管理工具(Maven/grade)的便捷性让人大快朵颐,再也不需要到处找jar包. 如果你没梯子又苦苦无法加快下载速度,不如按照以下设置一下. 对单个项 ...
- msyql [note] mysqld (mysqld 5.6.40) starting as process xxxx...
my.ini有2个配置一个是客户端[client],一个是服务器端[mysqld] 如果把2个都设置为utf8,那么中文会显示乱码,或者无法插入中文 而把客户端设置为gbk,把服务器端设置为utf8就 ...
- 内置函数 hashlib configparser logging 模块 C/S B/S架构
1.内置函数 # 内置的方法有很多 # 不一定全都在object中 # class Classes: # def __init__(self,name): # self.name = name # s ...
- Cmder安装配置
转: 1)Windows 命令行增强 cmder chocolatey 配置指南 2) Windows必备神器Cmder使用教程 3)Windows上的程序员神器——Cmder 4)Windows命令 ...