IOI '07 - Zagreb, Croatia
In 1964 a catastrophic flood struck the city of Zagreb. Many buildings were completely destroyed when the water struck their walls. In this task, you are given a simplified model of the city before the flood and you should determine which of the walls are left intact after the flood.
The model consists of points in the coordinate plane and walls. Each wall connects a pair of points and does not go through any other points. The model has the following additional properties:
- No two walls intersect or overlap, but they may touch at endpoints;
- Each wall is parallel to either the horizontal or the vertical coordinate axis.
Initially, the entire coordinate plane is dry. At time zero, water instantly floods the exterior (the space not bounded by walls). After exactly one hour, every wall with water on one side and air on the other breaks under the pressure of water. Water then floods the new area not bounded by any standing walls. Now, there may be new walls having water on one side and air on the other. After another hour, these walls also break down and water floods further. This procedure repeats until water has flooded the entire area.
An example of the process is shown in the following figure.
The state at time zero. Shaded cells represent the flooded area, while white cells represent dry area (air).
The state after one hour.
The state after two hours. Water has flooded the entire area and the remaining walls cannot be broken down.
Write a program that, given the coordinates of the points, and the descriptions of walls connecting these points, determines which of the walls are left standing after the flood.
Input Specification
The first line of input contains an integer , the number of points in the plane.
Each of the following lines contains two integers and (both between and , inclusive), the coordinates of one point. The points are numbered to in the order in which they are given. No two points will be located at the same coordinates.
The following line contains an integer , the number of walls.
Each of the following lines contains two different integers and , meaning that, before the flood, there was a wall connecting points and . The walls are numbered to in the order in which they are given.
Output Specification
The first line of output should contain a single integer , the number of walls left standing after the flood.
The following lines should contain the indices of the walls that are still standing, one wall per line. The indices may be output in any order.
Grading
In test cases worth a total of of the points, all coordinates will be at most .
In those same cases, and cases worth another of the points, the number of points will be at most .
Sample Input
15
1 1
8 1
4 2
7 2
2 3
4 3
6 3
2 5
4 5
6 5
4 6
7 6
1 8
4 8
8 8
17
1 2
2 15
15 14
14 13
13 1
14 11
11 12
12 4
4 3
3 6
6 5
5 8
8 9
9 11
9 10
10 7
7 6
Sample Output
4
6
15
16
17
This example corresponds to the figure above.
Comments