题意:

Information

Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 275 Accepted Submission(s): 33

Problem Description
军情紧急,我们需要立刻开发出一个程序去处理前线侦察兵发回的情报,并做出相应的分析。现在由你负责其中的一个子模块,你需要根据情报计算出敌方坦克的位置。

当敌方坦克静止时,侦察兵会尽力估算出它们之间的位置,而每当敌方坦克移动时,侦察兵都会记录下坦克新的位置并向你报告。每个坦克的位置可以由一个二维整数坐标来描述。

前线发回的情报有四种格式:

1 A B X Y

表示A坦克移动到了与B坦克的相对位置是(X,Y)的地方,即XA = XB + X, YA=YB+Y。

2 A X Y

表示A坦克移动到了绝对位置是(X,Y)的地方,即XA = X, YA = Y。

3 A B X Y

表示发现了A坦克与B坦克的相对位置是(X,Y),即XA = XB + X, YA=YB+Y。

4 A X Y

表示发现了A坦克的绝对位置是(X,Y),即XA = X, YA = Y。

我们需要你对于如下两种询问及时做出回应:

5 A B

表示询问A坦克与B坦克的相对位置是多少,即分别求出XA - XB 以及YA -YB

6 A

表示询问A坦克的绝对位置是多少,即求出XA 和YA

其中A和B代表的是任意的一个坦克的编号,(X,Y)表示了坦克的二维坐标。你可以假设初始时刻我们对于敌方任何坦克的位置都一无所知,在此之后坦克的每一次移动都被侦察兵侦察到了。

请注意两个坦克的坐标有可能相同。
Input
输入的第一行是一个整数T(T < 1000),表示共有T组数据。

对于每组数据,第一行有一个整数N,表示这组数据有N次查询。接下来的每行表示一次查询,每次查询第一个数字代表是哪种询问,询问的格式详见上文。

数据范围:

0 < N <=100000, 0<A,B<=N 且 A<>B, X和Y都是整数且 0 <=X,Y<=10000 .

测试数据中98%的数据N不超过50。
Output
对于每组数据,首先需要输出单独一行”Case #?:”,其中问号处应填入当前的数据组数,组数从1开始计算。

对于每一个类型(1)或者(2)的询问,请把它们加入到你的记录中。

对于每一个类型(3)或者(4)的询问,如果与之前记录的内容有矛盾,请输出”REJECT”并将这个情报忽略掉,如没有矛盾,请把它们加入到你的记录中。

对于每一个类型(5)或者(6)的询问,如果根据之前的记录能推出结论,请输出两个整数X和Y,两个整数之间有一个空格;如果不能推出结论,请输出”UNKNOWN”。输出的所有信息都不包括引号。
Sample Input

2
7
1 1 2 3 4
2 3 4 5
3 4 5 2 1
4 6 2 2
3 2 4 6 2
5 4 1
6 3
6
6 3
4 3 2 2
6 3
2 4 2 3
5 3 4
3 3 4 1 2
Sample Output

Case #1:
-9 -6
4 5
Case #2:
UNKNOWN
2 2
0 -1
REJECT

思路:

       这个题目做了好久了,各种纠结,原因是自己吧自己绕道圈子里面了,越绕越复杂

,看到这个题目直接就想到带权并查集,这个毫无疑问,同时还想到1,2都是创建先的节点,但关键是在hash节点和判断当前这个集合时候是已知点的时候sb了,后来蒙了,当时我是标记父亲节点,每次要是有个点是已知的,那么就直接吧他的当前父亲节点标记上,结果各种wa,就这样不知wa了多久,后来看了别人的处理方式,哎!真的是先想好在敲啊,思路直接敲有的时候会死的很惨的啊,对于1,2,是要建立新的节点的,其余的不用,对于已知的点,直接把他父亲连接到0节点上,0节点就表示是已知的(可以是别的自己随意),这样写的时候就简单多了,对于hash点的时候,我是来一个hash一个,不来不用,具体看代码。

#include<stdio.h>

#define N 200000

int
mer[N] ,X[N] ,Y[N] ,hash[N]; int finds(int x)
{
if(
x == mer[x]) return x;
int
t = mer[x];
mer[x] = finds(mer[x]);
X[x] += X[t];
Y[x] += Y[t];
return
mer[x];
} int main ()
{
int
t ,n ,cas = 1;
int
key ,a ,b ,x ,y;
scanf("%d" ,&t);
while(
t--)
{

scanf("%d" ,&n);
printf("Case #%d:\n" ,cas ++);
for(int
i = 0 ;i <= n * 2 ;i ++)
mer[i] = i ,X[i] = Y[i] = 0 ,hash[i] = -1;
int
nown = 0;
hash[0] = 0;
while(
n--)
{

scanf("%d" ,&key);
if(
key == 1 || key == 2)
{
if(
key == 1)
scanf("%d %d %d %d" ,&a ,&b ,&x ,&y);
else
{

scanf("%d %d %d" ,&a ,&x ,&y);
b = 0;
}

hash[a] = ++nown;
if(
hash[b] == -1) hash[b] = ++nown;
int
ra = finds(hash[a]) ,rb = finds(hash[b]);
mer[ra] = rb;
X[ra] = X[hash[b]] - X[hash[a]] + x;
Y[ra] = Y[hash[b]] - Y[hash[a]] + y;
}
if(
key == 3 || key == 4)
{
if(
key == 3)
scanf("%d %d %d %d" ,&a ,&b ,&x ,&y);
else
{

b = 0;
scanf("%d %d %d" ,&a ,&x ,&y);
}
if(
hash[a] == -1) hash[a] = ++nown;
if(
hash[b] == -1) hash[b] = ++nown;
int
ra = finds(hash[a]) ,rb = finds(hash[b]);
if(
ra == rb)
{
if(
X[hash[a]] - X[hash[b]] != x || Y[hash[a]] - Y[hash[b]] != y)
printf("REJECT\n");
}
else
{

mer[ra] = rb;
X[ra] = X[hash[b]] - X[hash[a]] + x;
Y[ra] = Y[hash[b]] - Y[hash[a]] + y;
}
}
if(
key == 5 || key == 6)
{
if(
key == 5)
scanf("%d %d" ,&a ,&b);
else
{

scanf("%d" ,&a);
b = 0;
}
if(
hash[a] == -1) hash[a] = ++nown;
if(
hash[b] == -1) hash[b] = ++nown;
int
ra = finds(hash[a]) ,rb = finds(hash[b]);
if(
ra != rb) printf("UNKNOWN\n");
else
printf("%d %d\n" ,X[hash[a]] - X[hash[b]] ,Y[hash[a]] - Y[hash[b]]);
}
}
}
return
0;
}

hdu4829 带权并查集(题目不错)的更多相关文章

  1. 洛谷 1196 [NOI2002]银河英雄传说【模板】带权并查集

    [题解] 经典的带权并查集题目. 设cnt[i]表示i前面的点的数量,siz[i]表示第i个点(这个点是代表元)所处的联通块的大小:合并的时候更新siz.旧的代表元的cnt,路径压缩的时候维护cnt即 ...

  2. 浅谈并查集&种类并查集&带权并查集

    并查集&种类并查集&带权并查集 前言: 因为是学习记录,所以知识讲解+例题推荐+练习题解都是放在一起的qvq 目录 并查集基础知识 并查集基础题目 种类并查集知识 种类并查集题目 并查 ...

  3. [NOIP摸你赛]Hzwer的陨石(带权并查集)

    题目描述: 经过不懈的努力,Hzwer召唤了很多陨石.已知Hzwer的地图上共有n个区域,且一开始的时候第i个陨石掉在了第i个区域.有电力喷射背包的ndsf很自豪,他认为搬陨石很容易,所以他将一些区域 ...

  4. poj1984 带权并查集(向量处理)

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

  5. hdu3038(带权并查集)

    题目链接: http://acm.split.hdu.edu.cn/showproblem.php?pid=3038 题意: n表示有一个长度为n的数组, 接下来有m行形如x, y, d的输入, 表示 ...

  6. 洛谷OJ P1196 银河英雄传说(带权并查集)

    题目描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦 创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山 ...

  7. hdu 1829-A Bug's LIfe(简单带权并查集)

    题意:Bug有两种性别,异性之间才交往, 让你根据数据判断是否存在同性恋,输入有 t 组数据,每组数据给出bug数量n, 和关系数m, 以下m行给出相交往的一对Bug编号 a, b.只需要判断有没有, ...

  8. Codeforces Educational Codeforces Round 5 C. The Labyrinth 带权并查集

    C. The Labyrinth 题目连接: http://www.codeforces.com/contest/616/problem/C Description You are given a r ...

  9. Codeforces Round #181 (Div. 2) B. Coach 带权并查集

    B. Coach 题目连接: http://www.codeforces.com/contest/300/problem/A Description A programming coach has n ...

随机推荐

  1. Win命令行切换Python版本

    目录 安装2.x 和 3.x 的python 设置系统环境变量 pip的使用 参考 安装2.x 和 3.x 的python 我这里使用anaconda来安装两个版本的python包. conda cr ...

  2. JVM之类加载器子系统

    类加载器子系统 作用 负责从文件系统或网络系统中加载class文件,class文件在开头有特殊的标记(魔术开头CA FE BA BE) ClassLoader只负责加载class文件,至于能否运行,由 ...

  3. PAT-1153(Decode Registration Card of PAT)+unordered_map的使用+vector的使用+sort条件排序的使用

    Decode Registration Card of PAT PAT-1153 这里需要注意题目的规模,并不需要一开始就存储好所有的满足题意的信息 这里必须使用unordered_map否则会超时 ...

  4. 使用 .NET CLI 构建项目脚手架

    前言 在微服务场景中,开发人员分配到不同的小组,系统会拆分为很多个微服务,有一点是,每个项目都需要单元测试,接口文档,WebAPI接口等,创建新项目这些都是重复的工作,而且还要保证各个项目结构的大体一 ...

  5. CSS垂直布局

    1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="U ...

  6. 001-Java学习前基础

    目录 前言 一.Java语言特性(简单概述) 二.JDK.JRE.JVM三者关系 三.java文件的加载与执行 前言 初次在博客园写博客,想通过这种方式把自己学过的东西梳理一遍,加深自己的记忆,笔记中 ...

  7. python那些需要知道的事儿——内存泄漏

    啥,内存也会泄露?漏了咋补?我的内存会不会越漏越小?咋一听到内存泄漏,本喵的脑子蹦出无数想法,所以到底啥是内存泄漏! 一.垃圾回收机制(GC)机制 在理解内存泄漏之前,需要补充一个知识,即GC机制(也 ...

  8. PAT (Basic Level) Practice (中文)1078 字符串压缩与解压 (20 分) 凌宸1642

    PAT (Basic Level) Practice (中文)1078 字符串压缩与解压 (20 分) 凌宸1642 题目描述: 文本压缩有很多种方法,这里我们只考虑最简单的一种:把由相同字符组成的一 ...

  9. CVE-2021-21402 Jellyfin任意文件读取

    CVE-2021-21402 Jellyfin任意文件读取 漏洞简介 jellyfin 是一个自由的软件媒体系统,用于控制和管理媒体和流媒体.它是 emby 和 plex 的替代品,它通过多个应用程序 ...

  10. 【Flutter 3-5】Flutter进阶教程——在Flutter中使用Lottie动画

    作者 | 弗拉德 来源 | 弗拉德(公众号:fulade_me) Lottie动画 在移动开发中总是需要展示一些动画特效,作为程序员的我们并不是很擅长用代码做动画,即便是有些动画可以实现,在跨平台的过 ...