Navigation Nightmare POJ - 1984 带权并查集
#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
const int N=4e4+;
// 东西 南北
int p[N],D[N],B[N];
struct node{
int x,y,d;
char op[];
}e[N];
void init()
{
for(int i = ; i < N ; i ++)
{
p[i] =i;
D[i] =;
B[i] =;
e[i].x=,e[i].y=,e[i].d=;
}
}
int find(int x)
{
if(p[x]!=x)
{
int root=find(p[x]);
D[x]+=D[p[x]];
B[x]+=B[p[x]];
p[x]=root;
}
return p[x];
}
void build(int x,int y,int d,char opr[])
{
int dx=find(x);
int dy=find(y);
if(dx!=dy)
{
p[dy]=dx;
//这里虽然是在东西方向,但是南北方向的权值数组也是要更新的因为a在b的正西方向d米
//其实是a在b东西方向,向西移动d米加上a在b南北方向上移动0米
if(opr[]=='E'||opr[]=='W')
{
//如果和正方向相同就是加上这个距离,规定东为正方向
if(opr[]=='E')
D[dy]=D[x]-D[y]+d;
if(opr[]=='W')
D[dy]=D[x]-D[y]-d;
B[dy]=B[x]-B[y];//什么都不加
}
else if(opr[]=='N'||opr[]=='S')
{
if(opr[]=='N')
B[dy]=B[x]-B[y]+d;
if(opr[]=='S')
B[dy]=B[x]-B[y]-d;
D[dy]=D[x]-D[y];
}
}
}
int main()
{
int n,m;
while(cin>>n>>m)
{
init();
for(int i=;i<=m;i++)
cin>>e[i].x>>e[i].y>>e[i].d>>e[i].op;
int t;
cin>>t;
int cnt=;
//c其实就是按照从小到大的方式输入
//所以我们可以边输入边建立
int ans;
for(int i=;i<t;i++)
{
int a,b,c;
cin>>a>>b>>c;
//在c之前的我们都给他建立了
while(cnt<=c)
{
build(e[cnt].x,e[cnt].y,e[cnt].d,e[cnt].op);
cnt++;
}
int da=find(a);
int db=find(b);
if(da!=db)
ans=-;
else
ans=abs(D[a]-D[b])+abs(B[a]-B[b]);
cout<<ans<<endl;
}
}
return ;
}
Navigation Nightmare POJ - 1984 带权并查集的更多相关文章
- POJ 1984 Navigation Nightmare 【经典带权并查集】
任意门:http://poj.org/problem?id=1984 Navigation Nightmare Time Limit: 2000MS Memory Limit: 30000K To ...
- 【poj 1984】&【bzoj 3362】Navigation Nightmare(图论--带权并查集)
题意:平面上给出N个点,知道M个关于点X在点Y的正东/西/南/北方向的距离.问在刚给出一定关系之后其中2点的曼哈顿距离((x1,y1)与(x2,y2):l x1-x2 l+l y1-y2 l),未知则 ...
- poj 1182 (带权并查集)
食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 71361 Accepted: 21131 Description ...
- poj 1733(带权并查集+离散化)
题目链接:http://poj.org/problem?id=1733 思路:这题一看就想到要用并查集做了,不过一看数据这么大,感觉有点棘手,其实,我们仔细一想可以发现,我们需要记录的是出现过的节点到 ...
- POJ 1703 带权并查集
直接解释输入了: 第一行cases. 然后是n和m代表有n个人,m个操作 给你两个空的集合 每个操作后面跟着俩数 D操作是说这俩数不在一个集合里. A操作问这俩数什么关系 不能确定:输出Not sur ...
- Parity game POJ - 1733 带权并查集
#include<iostream> #include<algorithm> #include<cstdio> using namespace std; <& ...
- 【POJ 1984】Navigation Nightmare(带权并查集)
Navigation Nightmare Description Farmer John's pastoral neighborhood has N farms (2 <= N <= 40 ...
- POJ 1984 Navigation Nightmare(二维带权并查集)
题目链接:http://poj.org/problem?id=1984 题目大意:有n个点,在平面上位于坐标点上,给出m关系F1 F2 L D ,表示点F1往D方向走L距离到点F2,然后给出一系 ...
- POJ1984:Navigation Nightmare(带权并查集)
Navigation Nightmare Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 7871 Accepted: 2 ...
随机推荐
- coroutine - 示例
分享流畅的python一书, coroutine 章节中的出租车仿真的例子. from collections import namedtuple import queue import random ...
- Nginx之美多商城前台部署
这里我们采用动静分离的方式来部署美多商城项目. 动态请求:采用uwsgi与Django进行通信处理动态业务. 静态请求:采用Ngins通过socket与uwsgi进行通信处理静态业务. 第一步:实现u ...
- php连接mySql数据库 示例
<?php header("content-type:text/html;charset=utf-8"); error_reporting(E_ALL); /* 连接数据库- ...
- Redis5.xc两种持久化方式以及主从复制配置
关注公众号:CoderBuff,回复"redis"获取<Redis5.x入门教程>完整版PDF. <Redis5.x入门教程>目录 第一章 · 准备工作 第 ...
- nethogs-linux程序网络使用情况
netthogs可以显示每个程序的网络传输情况安装nethogs工具yum install https://mirrors.tuna.tsinghua.edu.cn/epel/7/x86_64/Pac ...
- 数组和CLR-非常特殊的关系
目录 数组和CLR-非常特殊的关系 公共语言运行时(CLR)的基础 内存和类型安全 实现细节 特殊帮助器类 移除边界检查 分配数组 运行时以不同的方式对待数组 进一步阅读 数组源码引用 参考文档 数组 ...
- 搭建fastdfs文件服务器
一.安装FastDFS环境 1.跟踪服务器(Tracker Server) tracker1:192.168.2.134 tracker2:192.168.2.135 2.存储服务器(Storage ...
- Arm开发板+Qt学习之路
从2015.11.13日开始接触arm开发板,开始学习Qt,到现在已经四个月零17天了,从一个拿到开发板一无所知的小白,到现在能够在开发板上进行开发,有付出有收获. 之前一直没有时间将这个过程中的一些 ...
- 【WPF学习】第四十九章 基本动画
在前一章已经学习过WPF动画的第一条规则——每个动画依赖于一个依赖项属性.然而,还有另一个限制.为了实现属性的动态化(换句话说,使用基于时间的方式改变属性的值),需要有支持相应数据类型的动画类.例如, ...
- 4,ZooKeeper原理
1,ZooKeeper概述 ··· 作用: · ZooKeeper是为分布式应用程序提供的一个分布式开源协调框架,是Hadoop和Hbase的重要组件: · 主要用于解决分布式集群中应 ...