码迷,mamicode.com
首页 > 其他好文 > 详细

Sicily 9016. Pablo Squarson's Headache

时间:2015-03-30 09:18:53      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:sicily

9016. Pablo Squarson‘s Headache

Constraints

Time Limit: 1 secs, Memory Limit: 256 MB

Description

Pablo Squarson is a well-known cubism artist. This year‘s theme for Pablo Squarson is "Squares". Today we are visiting his studio to see how his masterpieces are given birth.

At the center of his studio, there is a huuuuuge table and beside it are many, many squares of the same size. Pablo Squarson puts one of the squares on the table. Then he places some other squares on the table in sequence. It seems his methodical nature forces him to place each square side by side to the one that he already placed on, with machine-like precision.

Oh! The first piece of artwork is done. Pablo Squarson seems satisfied with it. Look at his happy face.

Oh, what‘s wrong with Pablo? He is tearing his hair! Oh, I see. He wants to find a box that fits the new piece of work but he has trouble figuring out its size. Let‘s help him!

Your mission is to write a program that takes instructions that record how Pablo made a piece of his artwork and computes its width and height. It is known that the size of each square is 1. You may assume that Pablo does not put a square on another.

I hear someone murmured "A smaller box will do". No, poor Pablo, shaking his head, is grumbling "My square style does not seem to be understood by illiterates".

技术分享

Input

The input consists of a number of datasets. Each dataset represents the way Pablo made a piece of his artwork. The format of a dataset is as follows.

N
n1 d1
n2 d2
...
nN-1 dN-1

The first line contains the number of squares (= N) used to make the piece of artwork. The number is a positive integer and is smaller than 200.

The remaining (N-1) lines in the dataset are square placement instructions. The line “ni di” indicates placement of the square numbered i (≤ N-1). The rules of numbering squares are as follows. The first square is numbered "zero". Subsequently placed squares are numbered 1, 2, ..., (N-1). Note that the input does not give any placement instruction to the first square, which is numbered zero.

A square placement instruction for the square numbered i, namely “ni di”, directs it to be placed next to the one that is numbered ni, towards the direction given by di, which denotes leftward (= 0), downward (= 1), rightward (= 2), and upward (= 3).

For example, pieces of artwork corresponding to the four datasets shown in Sample Input are depicted below. Squares are labeled by their numbers.

技术分享

The end of the input is indicated by a line that contains a single zero.

 

Output

 

For each dataset, output a line that contains the width and the height of the piece of artwork as decimal numbers, separated by a space. Each line should not contain any other characters.

 

 

Sample Input

1
5
0 0
0 1
0 2
0 3
12
0 0
1 0
2 0
3 1
4 1
5 1
6 2
7 2
8 2
9 3
10 3
10
0 2
1 2
2 2
3 2
2 1
5 1
6 1
7 1
8 1
0

Sample Output

1 1
3 3
4 4
5 6

Problem Source

2013年每周一赛第八场 Asia Regional Contest 2010 in Tokyo

#include <string.h>
#include <vector>
#include <queue>
#include <stdio.h>
#include <stack>
using namespace std;

struct Square {//只要用个结构体储存每个顺序的点的坐标就好了,图都不用建
    int pos_i;
    int pos_j;
}s[205];

int main() {
    int n, i, dir, temp, max_i, min_i, max_j, min_j;
    while (scanf("%d", &n) && n != 0) {
        s[0].pos_i = 0;
        s[0].pos_j = 0;
        min_i = max_i = min_j = max_j = 0;
        for (i = 1; i < n; i++) {
            scanf("%d %d", &temp, &dir);
            if (dir == 0) {
                s[i].pos_i = s[temp].pos_i;
                s[i].pos_j = s[temp].pos_j - 1;
            } else if (dir == 1) {
                s[i].pos_i = s[temp].pos_i + 1;
                s[i].pos_j = s[temp].pos_j;
            } else if (dir == 2) {
                s[i].pos_i = s[temp].pos_i;
                s[i].pos_j = s[temp].pos_j + 1;
            } else {
                s[i].pos_i = s[temp].pos_i - 1;
                s[i].pos_j = s[temp].pos_j;
            }
            
            if (s[i].pos_i < min_i)//随时更新最大最小长宽
                min_i = s[i].pos_i;
            if (s[i].pos_i > max_i)
                max_i = s[i].pos_i;
            if (s[i].pos_j < min_j)
                min_j = s[i].pos_j;
            if (s[i].pos_j > max_j)
                max_j = s[i].pos_j;
        }
        
        printf("%d %d\n", max_j - min_j + 1, max_i - min_i + 1);
    }
        
    return 0;
}                       


Sicily 9016. Pablo Squarson's Headache

标签:sicily

原文地址:http://blog.csdn.net/u012925008/article/details/44739789

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!