约翰和他的邻居生活在一个村庄里,他们的道路修建的很特别,都是正东正西或者正南正北,但是呢他们用一种方式描述他们和邻居的位置,比如说 6号 在1号 东面13处,那么我们就可以计算出来这两家的曼哈顿距离,也就是|x-x1| + |y-y1|, 当然这是让我们来求距离的.....
这个约翰也是比较特殊,他会一秒说出来一条道路的位置,当然在说的时候也会有一些查询,查询也是比较特别的,就是给三个参数,第一个第二个是描述的位置,第三个是时间,就是问前这些时间能不能算出他们的距离是多少?不能的话输出 -1 ,能的话输出曼哈顿距离。
分析:首先看这题想的是建立一个坐标系,让根节点是 0 0,然后可以计算根节点和他们之间的距离,不过这样的办法很难区间合并,所以pass,又想了一个办法,直接记录东西南北四个方向的位置,比方说A在B的东20,西40,这样就可以解决合并问题了,只需要把父节点的值加上也可以更新了。
////////////////////////////////////////////////////////+
竟然一下就对了........幸福来得太突然
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<queue>
#include<stack>
using namespace std; const int maxn = ; int f[maxn];
struct Point{int E, N;}val[maxn];//记录相对位置
struct node{int u, v, len, op;}data[maxn];
int dir[] = {, -, -, };//代表东西南北 int Find(int x)
{
    int k = f[x];
    if(f[x] != x)
    {
        f[x] = Find(f[x]);
        val[x].E += val[k].E;
        val[x].N += val[k].N;
    }     return f[x];
}
void Union(int u, int v, int len, int op)
{
    int ru = Find(u), rv = Find(v);     if(ru != rv)
    {
        f[rv] = ru;//别倒着写,因为有方向是B在A的位置
        val[rv].E = -val[v].E + val[u].E + len * dir[op] * (op <  ?  : );
        val[rv].N = -val[v].N + val[u].N + len * dir[op] * (op >  ?  : );
    }
} int main()
{
    int i, N, M;     while(scanf("%d%d", &N, &M) != EOF)
    {
        char s[];         for(i=; i<=N; i++)
        {
            f[i] = i;
            val[i].E = val[i].N = ;
        }         for(i=; i<=M; i++)
        {
            scanf("%d%d%d%s", &data[i].u, &data[i].v, &data[i].len, s);
            if(s[] == 'E')
                data[i].op = ;
            else if(s[] == 'W')
                data[i].op = ;
            else if(s[] == 'S')
                data[i].op = ;
            else
                data[i].op = ;
        }         int Q, u, v, ru, rv;         scanf("%d", &Q);         i = ;
        while(Q--)
        {
            scanf("%d%d%d", &u, &v, &M);             while(i <= M)
            {
                Union(data[i].u, data[i].v, data[i].len, data[i].op);
                i++;
            }             ru = Find(u), rv = Find(v);             if(ru != rv)
                printf("-1\n");
            else
            {
                int ans = (int)(fabs(val[u].E-val[v].E) + fabs(val[u].N-val[v].N));
                printf("%d\n", ans);
            }
        }
    }     return ;

}

I - Navigation Nightmare-poj 1984的更多相关文章

  1. Navigation Nightmare POJ - 1984

    Navigation Nightmare Farmer John's pastoral neighborhood has N farms (2 <= N <= 40,000), usual ...

  2. Navigation Nightmare POJ - 1984 带权并查集

    #include<iostream> #include<cmath> #include<algorithm> using namespace std; ; // 东 ...

  3. 【POJ 1984】Navigation Nightmare(带权并查集)

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

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

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

  5. POJ 1984 Navigation Nightmare 带全并查集

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

  6. POJ 1984 Navigation Nightmare (数据结构-并检查集合)

    Navigation Nightmare Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 4072   Accepted: 1 ...

  7. POJ1984:Navigation Nightmare(带权并查集)

    Navigation Nightmare Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 7871   Accepted: 2 ...

  8. POJ1984 Navigation Nightmare —— 种类并查集

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

  9. BZOJ_3362_[Usaco2004 Feb]Navigation Nightmare 导航噩梦_并查集

    BZOJ_3362_[Usaco2004 Feb]Navigation Nightmare 导航噩梦_并查集 Description     农夫约翰有N(2≤N≤40000)个农场,标号1到N,M( ...

  10. poj 1984 并查集

    题目意思是一个图中,只有上下左右四个方向的边.给出这样的一些边, 求任意指定的2个节点之间的距离. 就是看不懂,怎么破 /* POJ 1984 并查集 */ #include <stdio.h& ...

随机推荐

  1. POJ 1584 A Round Peg in a Ground Hole 判断凸多边形,判断点在凸多边形内

    A Round Peg in a Ground Hole Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5456   Acc ...

  2. BeautifulSoup在Windows下安装(running 2to3)

    在windows下安装beautifulsoup经常会出现说是在python3下无法运行Python2的代码,这时需要将Python下的tool下的scripts目录添加到环境变量中,然后运行2to3 ...

  3. retrofit2 okhttp3 RxJava butterknife 示例

    eclipse的jar包配置 eclipse中貌似用不了butterknife buildToolsVersion "23.0.2" defaultConfig { applica ...

  4. codevs愚蠢的矿工(树形DP)

    /* 树形DP 根节点一定有人 然后 剩下的人没到每个孩子去 因为孩子数可能很多 不好枚举 所以转二叉树 分两部分 O(sum)就可以了 当然 转二叉树候必须顾及原来树的一些性质 如不能只选左孩子 转 ...

  5. 转:Android中的Selector的用法

    http://blog.csdn.net/shakespeare001/article/details/7788400

  6. (转)php中__autoload()方法详解

    转之--http://www.php100.com/html/php/lei/2013/0905/5267.html PHP在魔术函数__autoload()方法出现以前,如果你要在一个程序文件中实例 ...

  7. SQL Server 2008中数据压缩

    SQL Server 2008中引入了数据压缩的功能,允许在表.索引和分区中执行数据压缩.这样不仅可以大大节省磁盘的占用空间,还允许将更多数据页装入内存中,从而降低磁盘IO,提升查询的性能.当然,凡事 ...

  8. 【转】iOS开发系列--数据存取

    原文: http://www.cnblogs.com/kenshincui/p/4077833.html#SQLite 概览 在iOS开发中数据存储的方式可以归纳为两类:一类是存储为文件,另一类是存储 ...

  9. iOS面试小题集锦

      1.Object-C有多继承吗?没有的话用什么代替? cocoa 中所有的类都是NSObject 的子类 多继承在这里是用protocol 委托代理 来实现的你不用去考虑繁琐的多继承 ,虚基类的概 ...

  10. Linux服务器指令

    1.查看cpu信息:/proc/cpuinfo2.查看内存信息:/prco/meminfo3.查看服务器版本信息:cat /etc/issue4.服务器系统位数:uname -a5.网卡信息:ifco ...