Elven Postman

Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)
Total Submission(s): 1091    Accepted Submission(s): 617

Problem Description
Elves are very peculiar creatures. As we all know, they can live for a very long time and their magical prowess are not something to be taken lightly. Also, they live on trees. However, there is something about them you may not know. Although delivering stuffs through magical teleportation is extremely convenient (much like emails). They still sometimes prefer other more “traditional” methods.

So, as a elven postman, it is crucial to understand how to deliver the mail to the correct room of the tree. The elven tree always branches into no more than two paths upon intersection, either in the east direction or the west. It coincidentally looks awfully like a binary tree we human computer scientist know. Not only that, when numbering the rooms, they always number the room number from the east-most position to the west. For rooms in the east are usually more preferable and more expensive due to they having the privilege to see the sunrise, which matters a lot in elven culture.

Anyways, the elves usually wrote down all the rooms in a sequence at the root of the tree so that the postman may know how to deliver the mail. The sequence is written as follows, it will go straight to visit the east-most room and write down every room it encountered along the way. After the first room is reached, it will then go to the next unvisited east-most room, writing down every unvisited room on the way as well until all rooms are visited.

Your task is to determine how to reach a certain room given the sequence written on the root.

For instance, the sequence 2, 1, 4, 3 would be written on the root of the following tree.

 
Input
First you are given an integer T(T≤10) indicating the number of test cases.

For each test case, there is a number n(n≤1000) on a line representing the number of rooms in this tree. n integers representing the sequence written at the root follow, respectively a1,...,an where a1,...,an∈{1,...,n}.

On the next line, there is a number q representing the number of mails to be sent. After that, there will be q integers x1,...,xq indicating the destination room number of each mail.

 
Output
For each query, output a sequence of move (E or W) the postman needs to make to deliver the mail. For that E means that the postman should move up the eastern branch and W the western one. If the destination is on the root, just output a blank line would suffice.

Note that for simplicity, we assume the postman always starts from the root regardless of the room he had just visited.

 
Sample Input
2
4
2 1 4 3
3
1 2 3
6
6 5 4 3 2 1
1
1
 
Sample Output
E WE EEEEE

题解:精灵族住在一颗倒着的二叉树上,这棵二叉树是从东到西编号,最东边是1,依次类推,邮递员要给精灵送信,每次邮递员都在最底下的点上,让输出邮递员的路径,思想就是建一颗倒着的二叉树,如果编号小就在东边建,也就是右边,大了就建在左边,每次建图直接把路径存上就妥了;

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std;
#define mem(x,y) memset(x,y,sizeof(x))
const int MAXN=1010;
vector<char>path[MAXN];
struct Node{
Node *L,*R;
int nu;
Node(int x=0):nu(x){
L=NULL;R=NULL;
}
}*rot;
void inst(int x){
Node *p=rot;
while(1){
if(x>p->nu){
path[x].push_back('W');
if(p->L==NULL){
p->L=new Node(x);
break;
}
else p=p->L;
}
else{
path[x].push_back('E');
if(p->R==NULL){
p->R=new Node(x);
break;
}
else p=p->R;
}
}
}
int main(){
int T,n,q;
scanf("%d",&T);
while(T--){
for(int i=0;i<MAXN;i++)path[i].clear();
scanf("%d",&n);
int x;
scanf("%d",&x);
rot=new Node(x);
for(int i=1;i<n;i++){
scanf("%d",&x);
inst(x);
}
scanf("%d",&q);
while(q--){
scanf("%d",&x);
for(int i=0;i<path[x].size();i++)
printf("%c",path[x][i]);
puts("");
}
}
return 0;
}

java:注意java的对象传递是引用类型, 但是tree = new Tree()会给tree重新分配一个jvm地址,这时候tree的改变不会使原值改变,此时变成了值传递,所以想了个思路,就是在类里面对属性复制,也就是newL(),newR()方法;

代码:

package com.lanqiao.week1;

import java.util.LinkedList;
import java.util.Scanner; public class hdu5444 {
private static Scanner cin = null;
static{
cin = new Scanner(System.in);
}
static class Tree{
public Tree l;
public Tree r;
public int value; public void newL(int v){
l = new Tree(null, null, v);
} public void newR(int v){
r = new Tree(null, null, v);
}
public static void insert(Tree t, int v){
if(v > t.value){
if(t.r != null)
insert(t.r, v);
else
t.newR(v);
}else{
if(t.l != null)
insert(t.l, v);
else
t.newL(v);
}
}
public static void visit(Tree t, int v){
if(t == null)
return;
if(v == t.value){
return;
}
if(v > t.value){
System.out.print("W");
visit(t.r, v);
}else{
System.out.print("E");
visit(t.l, v);
}
}
public Tree() {
super();
}
public Tree(Tree l, Tree r, int value) {
this.l = l;
this.r = r;
this.value = value;
}
}
public static void main(String[] args) {
int T, n, q, a, v;
T = cin.nextInt();
while(T-- > 0){
n = cin.nextInt();
a = cin.nextInt();
Tree t = new Tree(null, null, a); for(int i = 1; i < n; i++){
a = cin.nextInt();
Tree.insert(t, a);
}
q = cin.nextInt();
//System.out.println(t);
while(q-- > 0){
v = cin.nextInt();
Tree.visit(t, v);
System.out.println();
}
}
}
}

Elven Postman(二叉树)的更多相关文章

  1. hdu 5444 Elven Postman 二叉树

    Time Limit: 1500/1000 MS (Java/Others)   Memory Limit: 131072/131072 K (Java/Others) Problem Descrip ...

  2. hdu 5444 Elven Postman(二叉树)——2015 ACM/ICPC Asia Regional Changchun Online

    Problem Description Elves are very peculiar creatures. As we all know, they can live for a very long ...

  3. (二叉树)Elven Postman -- HDU -- 54444(2015 ACM/ICPC Asia Regional Changchun Online)

    http://acm.hdu.edu.cn/showproblem.php?pid=5444 Elven Postman Time Limit: 1500/1000 MS (Java/Others)  ...

  4. hdu 5444 Elven Postman

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5444 Elven Postman Description Elves are very peculia ...

  5. 2015 ACM/ICPC Asia Regional Changchun Online HDU 5444 Elven Postman【二叉排序树的建树和遍历查找】

    Elven Postman Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  6. hdu 5444 Elven Postman(长春网路赛——平衡二叉树遍历)

    题目链接:pid=5444http://">http://acm.hdu.edu.cn/showproblem.php?pid=5444 Elven Postman Time Limi ...

  7. Elven Postman(BST )

    Elven Postman Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  8. Hdu 5444 Elven Postman dfs

    Elven Postman Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid= ...

  9. HDU 5444 Elven Postman (2015 ACM/ICPC Asia Regional Changchun Online)

    Elven Postman Elves are very peculiar creatures. As we all know, they can live for a very long time ...

随机推荐

  1. 关于 OnCloseQuery: 顺序、不能关机等(所有的windows的广播消息都是逐窗口传递的)——如果一个窗体的OnCloseQuery事件中如果写了代码那么WM_QUERYENDSESSION消息就传不过去了msg.result会返回0,关机事件也就停止了

    系统关闭窗体的事件顺序为: OnCloseQuery ----> OnClose ----> OnDestroy 下面的代码说明问题: unit Unit3; interface uses ...

  2. Home | WebScraping.com

    Home | WebScraping.com We specialize in extracting data from websites, which is known as web scrapin ...

  3. Objective-C浅拷贝和深拷贝

    浅拷贝就是对内存地址的复制,让目标对象指针和源对象指向同一片内存空间 如: char* str = (char*)malloc(100);char* str2 = str; 浅拷贝只是对对象的简单拷贝 ...

  4. YUV / RGB 格式及快速转换算法

    1 前言 自然界的颜色千变万化,为了给颜色一个量化的衡量标准,就需要建立色彩空间模型来描述各种各样的颜色,由于人对色彩的感知是一个复杂的生理和心理联合作用 的过程,所以在不同的应用领域中为了更好更准确 ...

  5. java 构造函数是如何执行的

    1.构造函数不是方法!! 原因1:方法的话,会直接执行方法体内的代码,但是构造函数首先执行的不是{}里的代码块,而是给对象的成员初始化: 2.方法可以被调用其他方法调用,但是构造函数不能被方法或变量调 ...

  6. 【转】android开发中关于模拟器emulation的常见问题

    [转]android开发中关于模拟器emulation的常见问题 Trouble: 无法启动android模拟器,提示 XDM authorization key matches an existin ...

  7. vim: 字符串替换

    :s/str1/str2/ 替换当前行第一个 str1 为 str2:s/str1/str2/g 替换当前行所有 str1 为 str2 ( 注意,  s/xx/xxx/g 语句从s开始,中间的空格视 ...

  8. SAE部署Java应用

    链接地址:http://blog.csdn.net/shuixin536/article/details/9031335 SAE为开发者提供了非常宽松的开发环境,你甚至不用做任何特别定制就能将各种Ja ...

  9. c++ 容器、继承层次、句柄类

    一.容器与继承 在容器中保存有继承关系的对象,如果定义成保存基类对象,则派生类将被切割,如果定义成保存派生类对象,则保存基类对象又成问题(基类对象将被强制转换成派生类对象,而派生类中定义的成员未被初始 ...

  10. vagrant 入门2

    创建第一个Vagrant虚拟环境以及工程: (1)创建工程目录, 并且执行vagrant init命令,该命令会产生最初的 Vagrantfile $ mkdir vagrant_guide $ cd ...