Package for this problem was not updated by the problem writer or Codeforces administration after we’ve upgraded the judging servers. To adjust the time limit constraint, solution execution time will be multiplied by 2. For example, if your solution works for 400 ms on judging servers, then value 800 ms will be displayed and used to determine the verdict.

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

F. BerPaint

time limit per test

5 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputAnfisa the monkey got disappointed in word processors as they aren't good enough at reflecting all the range of her emotions, that's why she decided to switch to graphics editors. Having opened the BerPaint, she saw a white rectangle *W* × *H* in size which can be painted on. First Anfisa learnt to navigate the drawing tool which is used to paint segments and quickly painted on that rectangle a certain number of black-colored segments. The resulting picture didn't seem bright enough to Anfisa, that's why she turned her attention to the "fill" tool which is used to find a point on the rectangle to paint and choose a color, after which all the area which is the same color as the point it contains, is completely painted the chosen color. Having applied the fill several times, Anfisa expressed her emotions completely and stopped painting. Your task is by the information on the painted segments and applied fills to find out for every color the total area of the areas painted this color after all the fills.

Input

The first input line has two integers *W* and *H* (3 ≤ *W*, *H* ≤ 10^{4}) — the sizes of the initially white rectangular painting area. The second line contains integer *n* — the number of black segments (0 ≤ *n* ≤ 100). On the next *n* lines are described the segments themselves, each of which is given by coordinates of their endpoints *x*_{1}, *y*_{1}, *x*_{2}, *y*_{2} (0 < *x*_{1}, *x*_{2} < *W*, 0 < *y*_{1}, *y*_{2} < *H*). All segments have non-zero length. The next line contains preset number of fills *m* (0 ≤ *m* ≤ 100). Each of the following *m* lines defines the fill operation in the form of "*x* *y* *color*", where (*x*, *y*) are the coordinates of the chosen point (0 < *x* < *W*, 0 < *y* < *H*), and *color* — a line of lowercase Latin letters from 1 to 15 symbols in length, determining the color. All coordinates given in the input are integers. Initially the rectangle is "white" in color, whereas the segments are drawn "black" in color.

Output

For every color present in the final picture print on the single line the name of the color and the total area of areas painted that color with an accuracy of 10^{ - 6}. Print the colors in any order.

Examples

Input

4 5

6

1 1 1 3

1 3 3 3

3 3 3 1

3 1 1 1

1 3 3 1

1 1 3 3

2

2 1 red

2 2 blue

Output

blue 0.00000000

white 20.00000000

Input

5 5

5

1 1 2 2

2 2 4 2

4 2 4 4

4 4 2 4

2 4 2 2

2

3 3 black

3 3 green

Output

green 4.00000000

white 21.00000000

Input

7 4

9

1 2 2 3

2 3 3 2

3 2 2 1

2 1 1 2

3 2 4 2

4 2 5 3

5 3 6 2

6 2 5 1

5 1 4 2

2

2 2 black

2 2 red

Output

red 2.00000000

white 26.00000000

Note

Initially the black segments painted by Anfisa can also be painted a color if any of the chosen points lays on the segment. The segments have areas equal to 0. That is why if in the final picture only parts of segments is painted some color, then the area, painted the color is equal to 0.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/18/2018 06:44:29 (d3).

Desktop version, switch to mobile version.

User lists

Name |
---|