Navigation Nightmare
Time Limit: 2000MS   Memory Limit: 30000K
Total Submissions: 4072   Accepted: 1615
Case Time Limit: 1000MS

Description

Farmer John's pastoral neighborhood has N farms (2 <= N <= 40,000), usually numbered/labeled 1..N. A series of M (1 <= M < 40,000) vertical and horizontal roads each of varying lengths (1 <= length <= 1000) connect the farms. A map of these farms might look
something like the illustration below in which farms are labeled F1..F7 for clarity and lengths between connected farms are shown as (n):

           F1 --- (13) ---- F6 --- (9) ----- F3

            |                                 |

           (3)                                |

            |                                (7)

           F4 --- (20) -------- F2            |

            |                                 |

           (2)                               F5

            | 

           F7 

Being an ASCII diagram, it is not precisely to scale, of course. 



Each farm can connect directly to at most four other farms via roads that lead exactly north, south, east, and/or west. Moreover, farms are only located at the endpoints of roads, and some farm can be found at every endpoint of every road. No two roads cross,
and precisely one path 

(sequence of roads) links every pair of farms. 



FJ lost his paper copy of the farm map and he wants to reconstruct it from backup information on his computer. This data contains lines like the following, one for every road: 



There is a road of length 10 running north from Farm #23 to Farm #17 

There is a road of length 7 running east from Farm #1 to Farm #17 

... 



As FJ is retrieving this data, he is occasionally interrupted by questions such as the following that he receives from his navigationally-challenged neighbor, farmer Bob: 



What is the Manhattan distance between farms #1 and #23?

FJ answers Bob, when he can (sometimes he doesn't yet have enough data yet). In the example above, the answer would be 17, since Bob wants to know the "Manhattan" distance between the pair of farms. 

The Manhattan distance between two points (x1,y1) and (x2,y2) is just |x1-x2| + |y1-y2| (which is the distance a taxicab in a large city must travel over city streets in a perfect grid to connect two x,y points). 



When Bob asks about a particular pair of farms, FJ might not yet have enough information to deduce the distance between them; in this case, FJ apologizes profusely and replies with "-1". 

Input

* Line 1: Two space-separated integers: N and M

* Lines 2..M+1: Each line contains four space-separated entities, F1,

        F2, L, and D that describe a road. F1 and F2 are numbers of

        two farms connected by a road, L is its length, and D is a

        character that is either 'N', 'E', 'S', or 'W' giving the

        direction of the road from F1 to F2.

* Line M+2: A single integer, K (1 <= K <= 10,000), the number of FB's

        queries

* Lines M+3..M+K+2: Each line corresponds to a query from Farmer Bob

        and contains three space-separated integers: F1, F2, and I. F1

        and F2 are numbers of the two farms in the query and I is the

        index (1 <= I <= M) in the data after which Bob asks the

        query. Data index 1 is on line 2 of the input data, and so on.

Output

* Lines 1..K: One integer per line, the response to each of Bob's

        queries.  Each line should contain either a distance

        measurement or -1, if it is impossible to determine the

        appropriate distance.

Sample Input

7 6
1 6 13 E
6 3 9 E
3 5 7 S
4 1 3 N
2 4 20 W
4 7 2 S
3
1 6 1
1 4 3
2 6 6

Sample Output

13
-1
10

Hint

At time 1, FJ knows the distance between 1 and 6 is 13. 

At time 3, the distance between 1 and 4 is still unknown. 

At the end, location 6 is 3 units west and 7 north of 2, so the distance is 10. 

Source

题目大意:

给定n个城市,m条边告诉你城市间的相对距离,接下来q组询问,问你在第几条边加入后两城市的距离。

解题思路:

用离线处理。再用并查集维护每一个城市到父亲城市的距离。

解题思路:

#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std; const int maxn=41000; struct edge{
int u,v,dis;
char ch;
}e[maxn]; struct node{
int u,v,cnt,id,ans;
}a[maxn]; int n,m,q;
int father[maxn],offx[maxn],offy[maxn]; bool cmp1(node x,node y){
return x.cnt<y.cnt;
} bool cmp2(node x,node y){
return x.id<y.id;
} void input(){
scanf("%d%d",&n,&m);
for(int i=0;i<=n;i++){
father[i]=i;
offx[i]=offy[i]=0;
}
for(int i=0;i<m;i++){
scanf("%d%d%d %c",&e[i].u,&e[i].v,&e[i].dis,&e[i].ch);
}
scanf("%d",&q);
for(int i=0;i<q;i++){
scanf("%d%d%d",&a[i].u,&a[i].v,&a[i].cnt);
a[i].id=i;
}
sort(a,a+q,cmp1);
} int find(int x){
if(father[x]!=x){
int tmp=father[x];
father[x]=find(father[x]);
offx[x]+=offx[tmp];
offy[x]+=offy[tmp];
}
return father[x];
} void combine(int x,int y,int dis,char ch){
int fx=find(x);
int fy=find(y);
father[fy]=fx;
int offx0=offx[x]-offx[y];
int offy0=offy[x]-offy[y];
//cout<<fy<<"->"<<fx;
if(ch=='N') offy0+=dis;
else if(ch=='S') offy0-=dis;
else if(ch=='E') offx0+=dis;
else offx0-=dis;
//cout<<":("<<offx[fy]<<","<<offy[fy]<<")"<<endl;
offx[fy]=offx0;
offy[fy]=offy0;
//cout<<":("<<offx[fy]<<","<<offy[fy]<<")"<<endl;
} void solve(){
int k=0;
for(int i=0;i<q;i++){
for(;k<a[i].cnt;k++){
if(find(e[k].u)!=find(e[k].v)){
combine(e[k].u,e[k].v,e[k].dis,e[k].ch);
}
}
if( find(a[i].u)!=find(a[i].v) ) a[i].ans=-1;
else{
int ans=abs(offx[a[i].u]-offx[a[i].v])+abs(offy[a[i].u]-offy[a[i].v]);
a[i].ans=ans;
}
}
sort(a,a+q,cmp2);
for(int i=0;i<q;i++){
printf("%d\n",a[i].ans);
}
} int main(){
input();
solve();
return 0;
}

版权声明:本文博客原创文章。博客,未经同意,不得转载。

POJ 1984 Navigation Nightmare (数据结构-并检查集合)的更多相关文章

  1. POJ 1984 Navigation Nightmare 【经典带权并查集】

    任意门:http://poj.org/problem?id=1984 Navigation Nightmare Time Limit: 2000MS   Memory Limit: 30000K To ...

  2. POJ 1984 Navigation Nightmare 带全并查集

    Navigation Nightmare   Description Farmer John's pastoral neighborhood has N farms (2 <= N <= ...

  3. POJ 1984 - Navigation Nightmare - [带权并查集]

    题目链接:http://poj.org/problem?id=1984 Time Limit: 2000MS Memory Limit: 30000K Case Time Limit: 1000MS ...

  4. POJ 1984 Navigation Nightmare(二维带权并查集)

    题目链接:http://poj.org/problem?id=1984 题目大意:有n个点,在平面上位于坐标点上,给出m关系F1  F2  L  D ,表示点F1往D方向走L距离到点F2,然后给出一系 ...

  5. poj 1984 Navigation Nightmare(带权并查集+小小的技巧)

    题目链接:http://poj.org/problem?id=1984 题意:题目是说给你n个线,并告知其方向,然后对于后面有一些询问,每个询问有一个时间点,要求你输出在该时间点a,b的笛卡尔距离,如 ...

  6. POJ 1984 Navigation Nightmare

    并查集,给n个点和m条边,每条边有方向和长度,再给q个询问,第i个询问查询两个点之间在Ti时刻时的曼哈顿距离(能连通则输出曼哈顿距离,否则输出-1) 这题跟Corporative Network 有点 ...

  7. BZOJ 3362 POJ 1984 Navigation Nightmare 并与正确集中检查

    标题效果:一些养殖场是由一些南北或东西向的道路互连. 镶上在不断的过程中会问两个农场是什么曼哈顿的距离,假设现在是不是通信.那么输出-1. 思维:并与正确集中检查,f[i]点i至father[i]距离 ...

  8. POJ - 1984 Navigation Nightmare 种类并查集

    思路:记录每个点与其根结点的横向距离和纵向距离,当知道其父节点与根结点的关系,很容易推出当前节点与根结点的关系: 直接相加即可. int p = a[x].par; a[x].dx += a[p].d ...

  9. poj 2513 Colored Sticks(欧拉路径+并检查集合+特里)

    题目链接:poj 2513 Colored Sticks 题目大意:有N个木棍,每根木棍两端被涂上颜色.如今给定每一个木棍两端的颜色.不同木棍之间拼接须要颜色同样的 端才干够.问最后是否能将N个木棍拼 ...

随机推荐

  1. Notifications(通知)

    通知 通知是能在应用的普通用户界面外显示给用户的一种消息. 当你告诉系统公布一条通知时,它首先在通知栏中表现为一枚图标. 用户打开通知抽屉后就能查看通知的细节了. 通知栏和通知抽屉都是由系统控制的区域 ...

  2. Struts2第一个工程helloStruts极其基本配置

    前面已经准备好了Struts-2.3.15,现在就可以直接搭建Struts2的工程了.前面http://blog.csdn.net/huangchnegdada/article/details/917 ...

  3. Ubuntu 使用中的问题总结

    1.ibus输入法图标消失 #ibus-daemon -d 2.Ubuntu没有声音 #alsamixer 3.“对不起,ubuntu出现了内部错误” # nano /etc/default/appo ...

  4. Spring 类构造器初始化实例

    构造方法类Bean1 package com.hao947.bean; public class Bean1 { public Bean1() { System.out.println("b ...

  5. 本地或者服务器同时启动2个或多个tomcat

    一,修改配置文件server.xml的端口 C:\apache-tomcat-5.5.23-1\conf\server.xml用记事本什么的打开修改3个地方   第一: <Server port ...

  6. C++ 在字符串中插入子串+推断字符串是否由空格组成

    // Example3.cpp : 定义控制台应用程序的入口点. #include "StdAfx.h" #include <string> #include < ...

  7. C++用于修饰的keyword

    1.const修饰指针 (1)const int *p=&x:不可改动*p的内容,但能够让指针p指向还有一个地址,和int const *p一样 (2)int *const p=&x: ...

  8. poj1236 有向图加边变成强连通图

    给我们一个有向图,有两个问题 1.最少要给多少个点发消息,才能使得所有的点都收到消息(消息可以随边传递) 2.最少需要多少条边才能使得图变成强连通图 对于一个强连通分量,可以当做一个点来考虑,所以我们 ...

  9. Android 权限添加

    在AndroidMainFest.xml中加上以下代码就行了 添加WiFi以及访问网络的权限: <uses-permission android:name="android.permi ...

  10. 使用zzip和minizip解压缩文件

    #include <zzip/zzip.h> #include <zlib.h> #include <zip.h> #include <unzip.h> ...