#include <stdio.h>
#include <algorithm>
#include <assert.h>
#include <set>
#include <map>
#include <complex>
#include <iostream>
#include <time.h>
#include <stack>
#include <stdlib.h>
#include <memory.h>
#include <bitset>
#include <math.h>
#include <string>
#include <string.h>
#include <queue>
#include <vector>
using namespace std;
const int MaxN = 1e5 + 10;
const int MOD = 1e9 + 7;
const int INF = 1e9;
typedef long double PrecisionType;
typedef pair < PrecisionType, PrecisionType > PointType;
const PrecisionType EPS = 1e-10;
struct Node {
PointType x;
int y, sz;
PrecisionType sq;
PointType lmost, rmost;
Node *l, *r;
Node() {
}
Node(PointType _x) : sq(0.0), x(_x), lmost(_x), rmost(_x), sz(1), y(rand() * RAND_MAX + rand()), l(NULL), r(NULL) {
}
friend int getSize(Node *t) {
return t != NULL ? t->sz : 0;
}
friend PrecisionType getSquare(Node *t) {
return t ? t->sq : 0;
}
friend void update(Node *t) {
if (t != NULL) {
t->sz = 1;
t->lmost = t->rmost = t->x;
t->sq = 0;
if (t->r != NULL) {
t->sq += t->r->sq;
t->sq += (PrecisionType)(+t->r->lmost.first - t->x.first) * (PrecisionType)(t->r->lmost.second + t->x.second);
t->rmost = t->r->rmost;
t->sz += t->r->sz;
}
if (t->l != NULL) {
t->sq += t->l->sq;
t->sq += (PrecisionType)(-t->l->rmost.first + t->x.first) * (PrecisionType)(t->l->rmost.second + t->x.second);
t->lmost = t->l->lmost;
t->sz += t->l->sz;
}
}
}
friend void split(Node *t, Node *&l, Node *&r, PointType x) {
if (!t) {
r = l = NULL;
return;
}
if (t->x.first <= x.first) {
split(t->r, t->r, r, x);
l = t;
update(l);
return;
}
split(t->l, l, t->l, x);
r = t;
update(r);
}
friend Node* merge(Node *l, Node *r) {
if (!l || !r) {
return l ? l : r;
}
if (l->y > r->y) {
l->r = merge(l->r, r);
update(l);
return l;
}
r->l = merge(l, r->l);
update(r);
return r;
}
};
PrecisionType dist(PointType a, PointType b) {
return hypotl(a.first - b.first + .0, a.second - b.second + .0);
}
PrecisionType dist2(PointType a, PointType b) {
return (b.first - a.first) * (b.first - a.first) + (b.second - a.second) * (b.second - a.second);
}
PrecisionType cw(PointType a, PointType b, PointType c) {
return (a.first - b.first) * (c.second - b.second) - (a.second - b.second) * (c.first - b.first);
}
bool upcw(PointType a, PointType b, PointType c) {
return cw(a, b, c) > 0;
}
bool dwcw(PointType a, PointType b, PointType c) {
return cw(a, b, c) < 0;
}
PrecisionType getY(PointType a, PointType b, PointType c) {
return (c.first - a.first) / (b.first - a.first) * (b.second - a.second) + a.second;
}
Node *leftFound(Node *root, PointType point, bool (*myCw)(PointType, PointType, PointType)) {
if (root->l != NULL) {
if (!myCw(root->l->rmost, root->x, point)) {
return leftFound(root->l, point, myCw);
}
}
if (root->r != NULL) {
if (myCw(root->x, root->r->lmost, point)) {
return leftFound(root->r, point, myCw);
}
}
return root;
}
Node *rightFound(Node *root, PointType point, bool (*myCw)(PointType, PointType, PointType)) {
if (root->r != NULL) {
if (!myCw(point, root->x, root->r->lmost)) {
return rightFound(root->r, point, myCw);
}
}
if (root->l != NULL) {
if (myCw(point, root->l->rmost, root->x)) {
return rightFound(root->l, point, myCw);
}
}
return root;
}
bool exist(Node *root, PointType p) {
if (!root) {
return false;
}
if (root->x.first == p.first) {
return true;
}
if (root->x.first < p.first) {
return exist(root->r, p);
}
return exist(root->l, p);
}
bool addPoint(vector < pair < PointType, Node* > > &roll, Node *&convexHull, PointType point, bool isUp, bool (*myCw)(PointType, PointType, PointType)) {
if (exist(convexHull, point)) {
return false;
}
if (!convexHull) {
convexHull = new Node(point);
roll.push_back(make_pair(point, (Node*)NULL));
return true;
}
if (convexHull->lmost <= point && point <= convexHull->rmost) {
Node *leftConvexHull, *rightConvexHull;
split(convexHull, leftConvexHull, rightConvexHull, point);
PointType l = leftConvexHull->rmost;
PointType r = rightConvexHull->lmost;
PrecisionType y = getY(l, r, point);
if (isUp == true && point.second > y || isUp == false && point.second < y) {
Node *whereL = leftFound(leftConvexHull, point, myCw);
Node *whereR = rightFound(rightConvexHull, point, myCw);
Node *a, *b;
split(leftConvexHull, leftConvexHull, a, make_pair(whereL->x.first, whereL->x.second));
split(rightConvexHull, b, rightConvexHull, make_pair(whereR->x.first - 1e-10, whereR->x.second));
convexHull = merge(leftConvexHull, merge(new Node(point), rightConvexHull));
roll.push_back(make_pair(point, merge(a, b)));
return true;
}
convexHull = merge(leftConvexHull, rightConvexHull);
return false;
}
if (point <= convexHull->lmost) {
Node *whereR = rightFound(convexHull, point, myCw);
Node *temp;
split(convexHull, temp, convexHull, make_pair(whereR->x.first - 1e-10, whereR->x.second));
roll.push_back(make_pair(point, temp));
convexHull = merge(new Node(point), convexHull);
} else {
Node *whereL = leftFound(convexHull, point, myCw);
Node *temp;
split(convexHull, convexHull, temp, make_pair(whereL->x.first, whereL->x.second));
roll.push_back(make_pair(point, temp));
convexHull = merge(convexHull, new Node(point));
}
return true;
}
PointType rotate(PointType point, PrecisionType ang) {
return PointType(point.first * cosl(ang) + point.second * sinl(ang), -point.first * sinl(ang) + point.second * cosl(ang));
}
void makeChange(Node *&upConvexHull,
Node *&downConvexHull,
vector < pair < PointType, Node* > > &upChanges,
vector < pair < PointType, Node* > > &downChanges,
PointType point) {
addPoint(upChanges, upConvexHull, point, true, upcw);
addPoint(downChanges, downConvexHull, point, false, dwcw);
}
void rollback(Node *&convexHull, vector < pair < PointType, Node* > > &roll, int oldSize) {
while (roll.size() > oldSize) {
PointType cur = roll.back().first;
Node *tree = roll.back().second;
Node *a, *b;
split(convexHull, convexHull, a, make_pair(cur.first - 1e-10, cur.second));
split(a, a, b, make_pair(cur.first + 1e-10, cur.second));
convexHull = merge(convexHull, merge(tree, b));
roll.pop_back();
}
}
void solve(Node *&upConvexHull,
Node *&downConvexHull,
vector < pair < PointType, Node* > > &upChanges,
vector < pair < PointType, Node* > > &downChanges,
vector < pair < char, PointType > > &queries,
vector < int > &wadd,
vector < int > &paired,
vector < PrecisionType > &answers,
int lbound, int rbound) {
int middle = (lbound + rbound) / 2;
int upch = upChanges.size(), dwch = downChanges.size();
vector < int > nadd;
for (int i = 0; i < (int)wadd.size(); ++i) {
int l = wadd[i], r = paired[l];
if (r < lbound || l > rbound) {
continue;
}
if (l <= lbound && r > rbound) {
makeChange(upConvexHull, downConvexHull, upChanges, downChanges, queries[l].second);
continue;
}
nadd.push_back(wadd[i]);
}
if (lbound != rbound) {
solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, nadd, paired, answers, lbound, middle);
solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, nadd, paired, answers, middle + 1, rbound);
} else {
answers[lbound] = abs((getSquare(upConvexHull) - getSquare(downConvexHull)) / 2.0);
}
rollback(upConvexHull, upChanges, upch);
rollback(downConvexHull, downChanges, dwch);
}
vector < PrecisionType > solveSmart(vector < pair < char, PointType > > queries) {
int q = (int)queries.size();
map < PointType, vector < int > > f;
vector < int > paired(q);
for (int i = 0; i < q; ++i) {
char type = queries[i].first;
PointType point = queries[i].second;
if (type == '+') {
f[point].push_back(i);
} else {
int where = f[point].back();
f[point].pop_back();
paired[where] = i;
paired[i] = where;
}
}
vector < int > wadd;
for (int i = 0; i < q; ++i) {
char type = queries[i].first;
PointType point = queries[i].second;
if (type == '+') {
wadd.push_back(i);
}
if (type == '-' || f[point].empty()) {
continue;
}
for (int j = 0; j < (int)f[point].size(); ++j) {
int where = f[point][j];
paired[where] = q;
}
f[point].clear();
}
vector < PrecisionType > ans(q);
Node *upConvexHull = NULL, *downConvexHull = NULL;
vector < pair < PointType, Node* > > upChanges, downChanges;
solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, wadd, paired, ans, 0, q - 1);
return ans;
}
namespace stupid {
vector < PointType > convexHull(vector < PointType > points) {
sort(points.begin(), points.end());
if (points.size() < 3) {
return points;
}
vector < PointType > up, down;
up.push_back(points[0]);
down.push_back(points[0]);
for (int i = 1; i < (int)points.size(); ++i) {
if (i == (int)points.size() - 1 || cw(points[0], points[i], points.back()) > 0) {
while (up.size() >= 2 && cw(up[up.size() - 2], up[up.size() - 1], points[i]) <= 0) {
up.pop_back();
}
up.push_back(points[i]);
}
if (i == (int)points.size() - 1 || cw(points[0], points[i], points.back()) < 0) {
while (down.size() >= 2 && cw(down[down.size() - 2], down[down.size() - 1], points[i]) >= 0) {
down.pop_back();
}
down.push_back(points[i]);
}
}
vector < PointType > res;
for (int i = 0; i < (int)up.size(); ++i) {
res.push_back(up[i]);
}
for (int i = (int)down.size() - 2; i > 0; --i) {
res.push_back(down[i]);
}
return res;
}
void solve(vector < pair < char, PointType > > queries) {
multiset < PointType > points;
for (int i = 0; i < (int)queries.size(); ++i) {
PointType point = queries[i].second;
if (queries[i].first == '+') {
points.insert(point);
} else {
if (points.find(point) != points.end()) {
points.erase(points.find(point));
}
}
PrecisionType ans = 0;
if (points.size() >= 3) {
vector < PointType > v(points.begin(), points.end());
v = convexHull(v);
if (v.size() >= 3) {
for (int i = 0; i < (int)v.size(); ++i) {
ans += (PrecisionType)(v[i].first - v[(i + 1) % v.size()].first) * (v[i].second + v[(i + 1) % v.size()].second);
}
}
}
long long res = (ans >= 0 ? (long long)(ans + 0.5) : (long long)(ans - 0.5));
printf("%lld.%lld\n", abs(res) / 2, abs(res) % 2 * 5);
}
}
};
int main() {
// freopen("input.txt", "r", stdin);
// freopen("output.txt", "w", stdout);
int t;
scanf("%d", &t);
while (t --> 0) {
int q;
scanf("%d", &q);
vector < pair < char, PointType > > queries(q);
for (int i = 0; i < q; ++i) {
int x, y;
scanf("\n%c%d%d", &queries[i].first, &x, &y);
queries[i].second.first = x;
queries[i].second.second = y;
}
// stupid::solve(queries);
// exit(0);
for (int i = 0; i < q; ++i) {
queries[i].second = rotate(queries[i].second, +13.0);
}
vector < PrecisionType > ans = solveSmart(queries);
for (int i = 0; i < (int)ans.size(); ++i) {
printf("%.1lf\n", (double)ans[i]);
}
}
return 0;
}
#include <stdio.h>
#include <algorithm>
#include <assert.h>
#include <set>
#include <map>
#include <complex>
#include <iostream>
#include <time.h>
#include <stack>
#include <stdlib.h>
#include <memory.h>
#include <bitset>
#include <math.h>
#include <string>
#include <string.h>
#include <queue>
#include <vector>
 
using namespace std;
 
const int MaxN = 1e5 + 10;
const int MOD = 1e9 + 7;
const int INF = 1e9;
 
typedef long double PrecisionType;
typedef pair < PrecisionType, PrecisionType > PointType;
 
const PrecisionType EPS = 1e-10;
 
struct Node {
  PointType x;
  int y, sz;
  PrecisionType sq;
  PointType lmost, rmost;
  Node *l, *r;
  Node() {
  }
  Node(PointType _x) : sq(0.0), x(_x), lmost(_x), rmost(_x), sz(1), y(rand() * RAND_MAX + rand()), l(NULL), r(NULL) {
  }
  friend int getSize(Node *t) {
    return t != NULL ? t->sz : 0;
  }
  friend PrecisionType getSquare(Node *t) {
    return t ? t->sq : 0;
  }
  friend void update(Node *t) {
    if (t != NULL) {
      t->sz = 1;
      t->lmost = t->rmost = t->x;
      t->sq = 0;
      if (t->r != NULL) {
        t->sq += t->r->sq;
        t->sq += (PrecisionType)(+t->r->lmost.first - t->x.first) * (PrecisionType)(t->r->lmost.second + t->x.second);
        t->rmost = t->r->rmost;
        t->sz += t->r->sz;
      }
      if (t->l != NULL) {
        t->sq += t->l->sq;
        t->sq += (PrecisionType)(-t->l->rmost.first + t->x.first) * (PrecisionType)(t->l->rmost.second + t->x.second);
        t->lmost = t->l->lmost;
        t->sz += t->l->sz;
      }
    }
  }
  friend void split(Node *t, Node *&l, Node *&r, PointType x) {
    if (!t) {
      r = l = NULL;
      return;
    }
    if (t->x.first <= x.first) {
      split(t->r, t->r, r, x);
      l = t;
      update(l);
      return;
    }
    split(t->l, l, t->l, x);
    r = t;
    update(r);
  }
  friend Node* merge(Node *l, Node *r) {
    if (!l || !r) {
      return l ? l : r;
    }
    if (l->y > r->y) {
      l->r = merge(l->r, r);
      update(l);
      return l;
    }
    r->l = merge(l, r->l);
    update(r);
    return r;
  }
};
 
PrecisionType dist(PointType a, PointType b) {
  return hypotl(a.first - b.first + .0, a.second - b.second + .0);
}
 
PrecisionType dist2(PointType a, PointType b) {
  return (b.first - a.first) * (b.first - a.first) + (b.second - a.second) * (b.second - a.second);
}
 
PrecisionType cw(PointType a, PointType b, PointType c) {
  return (a.first - b.first) * (c.second - b.second) - (a.second - b.second) * (c.first - b.first);
}
 
bool upcw(PointType a, PointType b, PointType c) {
  return cw(a, b, c) > 0;
}
 
bool dwcw(PointType a, PointType b, PointType c) {
  return cw(a, b, c) < 0;
}
 
PrecisionType getY(PointType a, PointType b, PointType c) {
  return (c.first - a.first) / (b.first - a.first) * (b.second - a.second) + a.second;
}
 
Node *leftFound(Node *root, PointType point, bool (*myCw)(PointType, PointType, PointType)) {
  if (root->l != NULL) {
    if (!myCw(root->l->rmost, root->x, point)) {
      return leftFound(root->l, point, myCw);
    }
  }
  if (root->r != NULL) {
    if (myCw(root->x, root->r->lmost, point)) {
      return leftFound(root->r, point, myCw);
    }
  }
  return root;
}
 
Node *rightFound(Node *root, PointType point, bool (*myCw)(PointType, PointType, PointType)) {
  if (root->r != NULL) {
    if (!myCw(point, root->x, root->r->lmost)) {
      return rightFound(root->r, point, myCw);
    }
  }
  if (root->l != NULL) {
    if (myCw(point, root->l->rmost, root->x)) {
      return rightFound(root->l, point, myCw);
    }
  }
  return root;
}
 
bool exist(Node *root, PointType p) {
  if (!root) {
    return false;
  }
  if (root->x.first == p.first) {
    return true;
  }
  if (root->x.first < p.first) {
    return exist(root->r, p);
  }
  return exist(root->l, p);
}
 
bool addPoint(vector < pair < PointType, Node* > > &roll, Node *&convexHull, PointType point, bool isUp, bool (*myCw)(PointType, PointType, PointType)) {
  if (exist(convexHull, point)) {
    return false;
  }
  if (!convexHull) {
    convexHull = new Node(point);
    roll.push_back(make_pair(point, (Node*)NULL));
    return true;
  }
  if (convexHull->lmost <= point && point <= convexHull->rmost) {
    Node *leftConvexHull, *rightConvexHull;
    split(convexHull, leftConvexHull, rightConvexHull, point);
    PointType l = leftConvexHull->rmost;
    PointType r = rightConvexHull->lmost;
    PrecisionType y = getY(l, r, point);
    if (isUp == true && point.second > y || isUp == false && point.second < y) {
      Node *whereL = leftFound(leftConvexHull, point, myCw);
      Node *whereR = rightFound(rightConvexHull, point, myCw);
      Node *a, *b;
      split(leftConvexHull, leftConvexHull, a,  make_pair(whereL->x.first, whereL->x.second));
      split(rightConvexHull, b, rightConvexHull, make_pair(whereR->x.first - 1e-10, whereR->x.second));
      convexHull = merge(leftConvexHull, merge(new Node(point), rightConvexHull));
      roll.push_back(make_pair(point, merge(a, b)));
      return true;
    }
    convexHull = merge(leftConvexHull, rightConvexHull);
    return false;
  }
  if (point <= convexHull->lmost) {
    Node *whereR = rightFound(convexHull, point, myCw);
    Node *temp;
    split(convexHull, temp, convexHull, make_pair(whereR->x.first - 1e-10, whereR->x.second));
    roll.push_back(make_pair(point, temp));
    convexHull = merge(new Node(point), convexHull);
  } else {
    Node *whereL = leftFound(convexHull, point, myCw);
    Node *temp;
    split(convexHull, convexHull, temp, make_pair(whereL->x.first, whereL->x.second));
    roll.push_back(make_pair(point, temp));
    convexHull = merge(convexHull, new Node(point));
  }
  return true;
}
 
PointType rotate(PointType point, PrecisionType ang) {
  return PointType(point.first * cosl(ang) + point.second * sinl(ang), -point.first * sinl(ang) + point.second * cosl(ang));
}
 
void makeChange(Node *&upConvexHull,
           Node *&downConvexHull,
           vector < pair < PointType, Node* > > &upChanges,
           vector < pair < PointType, Node* > > &downChanges,
           PointType point) {
  addPoint(upChanges, upConvexHull, point, true, upcw);
  addPoint(downChanges, downConvexHull, point, false, dwcw);
}
 
void rollback(Node *&convexHull, vector < pair < PointType, Node* > > &roll, int oldSize) {
  while (roll.size() > oldSize) {
    PointType cur = roll.back().first;
    Node *tree = roll.back().second;
    Node *a, *b;
    split(convexHull, convexHull, a, make_pair(cur.first - 1e-10, cur.second));
    split(a, a, b, make_pair(cur.first + 1e-10, cur.second));
    convexHull = merge(convexHull, merge(tree, b));
    roll.pop_back();
  }
}
 
void solve(Node *&upConvexHull,
           Node *&downConvexHull,
           vector < pair < PointType, Node* > > &upChanges,
           vector < pair < PointType, Node* > > &downChanges,
           vector < pair < char, PointType > > &queries,
           vector < int > &wadd,
           vector < int > &paired,
           vector < PrecisionType > &answers,
           int lbound, int rbound) {
  int middle = (lbound + rbound) / 2;
  int upch = upChanges.size(), dwch = downChanges.size();
  vector < int > nadd;
  for (int i = 0; i < (int)wadd.size(); ++i) {
    int l = wadd[i], r = paired[l];
    if (r < lbound || l > rbound) {
      continue;
    }
    if (l <= lbound && r > rbound) {
      makeChange(upConvexHull, downConvexHull, upChanges, downChanges, queries[l].second);
      continue;
    }
    nadd.push_back(wadd[i]);
  }
  if (lbound != rbound) {
    solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, nadd, paired, answers, lbound, middle);
    solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, nadd, paired, answers, middle + 1, rbound);
  } else {
    answers[lbound] = abs((getSquare(upConvexHull) - getSquare(downConvexHull)) / 2.0);
  }
  rollback(upConvexHull, upChanges, upch);
  rollback(downConvexHull, downChanges, dwch);
}
 
vector < PrecisionType > solveSmart(vector < pair < char, PointType > > queries) {
  int q = (int)queries.size();
  map < PointType, vector < int > > f;
  vector < int > paired(q);
  for (int i = 0; i < q; ++i) {
    char type = queries[i].first;
    PointType point = queries[i].second;
    if (type == '+') {
      f[point].push_back(i);
    } else {
      int where = f[point].back();
      f[point].pop_back();
      paired[where] = i;
      paired[i] = where;
    }
  }
  vector < int > wadd;
  for (int i = 0; i < q; ++i) {
    char type = queries[i].first;
    PointType point = queries[i].second;
    if (type == '+') {
      wadd.push_back(i);
    }
    if (type == '-' || f[point].empty()) {
      continue;
    }
    for (int j = 0; j < (int)f[point].size(); ++j) {
      int where = f[point][j];
      paired[where] = q;
    }
    f[point].clear();
  }
  vector < PrecisionType > ans(q);
  Node *upConvexHull = NULL, *downConvexHull = NULL;
  vector < pair < PointType, Node* > > upChanges, downChanges;
  solve(upConvexHull, downConvexHull, upChanges, downChanges, queries, wadd, paired, ans, 0, q - 1);
  return ans;
}
 
namespace stupid {
  vector < PointType > convexHull(vector < PointType > points) {
    sort(points.begin(), points.end());
    if (points.size() < 3) {
      return points;
    }
    vector < PointType > up, down;
    up.push_back(points[0]);
    down.push_back(points[0]);
    for (int i = 1; i < (int)points.size(); ++i) {
      if (i == (int)points.size() - 1 || cw(points[0], points[i], points.back()) > 0) {
        while (up.size() >= 2 && cw(up[up.size() - 2], up[up.size() - 1], points[i]) <= 0) {
          up.pop_back();
        }
        up.push_back(points[i]);
      }
      if (i == (int)points.size() - 1 || cw(points[0], points[i], points.back()) < 0) {
        while (down.size() >= 2 && cw(down[down.size() - 2], down[down.size() - 1], points[i]) >= 0) {
          down.pop_back();
        }
        down.push_back(points[i]);
      }
    }
    vector < PointType > res;
    for (int i = 0; i < (int)up.size(); ++i) {
      res.push_back(up[i]);
    }
    for (int i = (int)down.size() - 2; i > 0; --i) {
      res.push_back(down[i]);
    }
    return res;
  }
 
  void solve(vector < pair < char, PointType > > queries) {
    multiset < PointType > points;
    for (int i = 0; i < (int)queries.size(); ++i) {
      PointType point = queries[i].second;
      if (queries[i].first == '+') {
        points.insert(point);
      } else {
        if (points.find(point) != points.end()) {
          points.erase(points.find(point));
        }
      }
      PrecisionType ans = 0;
      if (points.size() >= 3) {
        vector < PointType > v(points.begin(), points.end());
        v = convexHull(v);
        if (v.size() >= 3) {
          for (int i = 0; i < (int)v.size(); ++i) {
            ans += (PrecisionType)(v[i].first - v[(i + 1) % v.size()].first) * (v[i].second + v[(i + 1) % v.size()].second);
          }
        }
      }
      long long res = (ans >= 0 ? (long long)(ans + 0.5) : (long long)(ans - 0.5));
      printf("%lld.%lld\n", abs(res) / 2, abs(res) % 2 * 5);
    }
  }
};
 
int main() {
 // freopen("input.txt", "r", stdin);
 // freopen("output.txt", "w", stdout);
  int t;
  scanf("%d", &t);
  while (t --> 0) {
    int q;
    scanf("%d", &q);
    vector < pair < char, PointType > > queries(q);
    for (int i = 0; i < q; ++i) {
      int x, y;
      scanf("\n%c%d%d", &queries[i].first, &x, &y);
      queries[i].second.first = x;
      queries[i].second.second = y;
    }
//    stupid::solve(queries);
//    exit(0);
    for (int i = 0; i < q; ++i) {
      queries[i].second = rotate(queries[i].second, +13.0);
    }
    vector < PrecisionType > ans = solveSmart(queries);
    for (int i = 0; i < (int)ans.size(); ++i) {
      printf("%.1lf\n", (double)ans[i]);
    }
  }
  return 0;
}
  