5112: Points on Plane

内存限制:256 MB 时间限制:2 S 标准输入输出
题目类型:传统 评测方式:文本比较 上传者:
提交:1 通过:1

题目描述

C. Points on Plane
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output
On a plane are n points (xi, yi) with integer coordinates between 0 and 106. The distance between the two points with numbers a and b is said to be the following value: (the distance calculated by such formula is called Manhattan distance).
We call a hamiltonian path to be some permutation pi of numbers from 1 to n. We say that the length of this path is value .
Find some hamiltonian path with a length of no more than 25×108. Note that you do not have to minimize the path length.
Input
The first line contains integer n (1≤n≤106).
The i+1-th line contains the coordinates of the i-th point: xi and yi (0≤xi,yi≤106).
It is guaranteed that no two points coincide.
Output
Print the permutation of numbers pi from 1 to n − the sought Hamiltonian path. The permutation must meet the inequality .
If there are multiple possible answers, print any of them.
It is guaranteed that the answer exists.
Examples
Input
5
0 7
8 10
3 4
5 0
9 12
Output
4 3 1 2 5 
Note
In the sample test the total distance is:

(|5-3|+|0-4|)+(|3-0|+|4-7|)+(|0-8|+|7-10|)+(|8-9|+|10-12|)=2+4+3+3+8+3+1+2=26

输入样例 复制


输出样例 复制