/*从昨晚开始想这题,看到队友有人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;
}