A New Door

All submissions for this problem are available.
Now Chef is very good in cooking; his dishes are the best in the city, so he wants to make his restaurant prettier. The first, what customer sees, when comes to his restaurant is the door. So he will start with it. He has found a new design last night. Hi will cut out some circles from the door and fill the holes by the glass to make windows of peculiar form.
Formally, we can model the process Chef will perform to create the windows as follows. Let the door be a rectangle at the coordinate plane with corners at the points (0, 0), (W, 0), (0, H), (W, H). Initially the door is colored white, while the remaining part of the coordinate plane is colored black. At each step Chef colors in black some circle including all its inner points. After Chef will color all required circles, the black part of the door (that is, black regions that lie in the rectangle corresponding to the door) is cut out and replaced by the glass.
The main measure of peculiarity of the door is the perimeter of all the windows considering only those parts of windows borders lying inside the door (see example case 2 for clarity). Chef is very tired after coloring so many circles and asks you to find this number.
Input
The first line of the input contains an integer T denoting the number of test cases. The description of T test cases follows. The first line of each test case contains 3 spaceseparated integers W, H, N, denoting the measurements of the door, and the number of circles. The description of N circles follows in the next N lines. Namely, the ith line among them contains 3 spaceseparated real numbers X, Y, R with exactly two digits after the decimal point, denoting the coordinates of the center and the radius of the circle that Chef will cut out at the ith step.
Output
For each test case, output a single line containing the sum of the perimeters of all windows as described above. Your answer will be considered as correct if it has an absolute error less than 10^{6}.
Constraints
 1 ≤ T ≤ 1000
 1 ≤ W ≤ 1000
 1 ≤ H ≤ 1000
 1 ≤ N ≤ 1000
 The sum of all values of N over the input does not exceed 5000
 0 < R ≤ 1000
 0 ≤ X, Y ≤ 1000
 X, Y, R have exactly two digits after the decimal point
 All circles are different, that is, every two circles have either different radii or different centers (or both)
Example
Input: 2 8 10 8 2.00 2.00 1.00 4.00 2.00 0.50 6.00 2.00 1.00 4.00 5.00 1.50 3.00 6.00 0.50 3.00 7.00 0.75 5.00 7.00 1.00 4.00 8.00 1.00 7 7 3 1.00 1.00 2.00 3.00 3.00 1.50 6.00 5.00 1.50 Output: 33.6404284 17.2058395
Explanation
Example case 1. The answer is the length of the bold lines on the following picture:
Example case 2. The answer is the length of the bold lines on the following picture:
Author:  witalij_hq 
Tester:  anton_lunyov 
Editorial  http://discuss.codechef.com/problems/ANDOOR 
Tags  geometry, jan13, medium, precision, witalij_hq 
Date Added:  9082012 
Time Limit:  6 sec 
Source Limit:  50000 Bytes 
Languages:  C, CPP14, JAVA, PYTH, PYTH 3.5, CS2, PAS fpc, PAS gpc, RUBY, PHP, GO, NODEJS, HASK, SCALA, D, PERL, FORT, WSPC, ADA, CAML, ICK, BF, ASM, CLPS, PRLG, ICON, SCM qobi, PIKE, ST, NICE, LUA, BASH, NEM, LISP sbcl, LISP clisp, SCM guile, JS, ERL, TCL, PERL6, TEXT, CLOJ, FS 
Comments
 Please login at the top to post a comment.
SUCCESSFUL SUBMISSIONS
Fetching successful submissions
HELP
If you are still having problems, see a sample solution here. 