/*从昨晚开始想这题,看到队友有人1Y很快过了,备受打击。然后就一直考虑各种情
况,各种debug,都没能过。下午另一个队友也很快1Y了,很纳闷,问了一下,搜的解题
报告,思路是把1*1的方格分成1000*1000个离散的点,然后统计被圆覆盖的点的个数。这
个方法实在有点。。。无语。发现有的人一不会就搜解题报告,没意思,宁愿浪费时间也
不那样做,这题算是间接的看得解题报告吧。检讨!*/
//Copy thinking code:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
using namespace std;
const int N = 11;
struct circle{
double x;
double y;
double r;
}c[N];
int n;
bool in_this_circle(int i, double a, double b){
double tmp = sqrt((a-c[i].x)*(a-c[i].x) + (b-c[i].y)*(b-c[i].y));
return tmp > c[i].r ? 0 : 1;
}
bool in_circle(double i, double j){
for(int x = 0; x < n; x++)
if(in_this_circle(x, i, j))
return true;
return false;
}
int main(){
//freopen("data.in", "r", stdin);
int k, cnt;
double i, j;
scanf("%d", &n);
for(k = 0; k < n; k++)
scanf("%lf%lf%lf", &c[k].x, &c[k].y, &c[k].r);
for(cnt = 0, i = 0; i <= 1; i += 0.001)
for(j = 0; j <= 1; j += 0.001)
if(in_circle(i, j))
cnt++;
printf("%lf\n", double(cnt)/(1000*1000)*100);
return 0;
}