#include <bits/stdc++.h>
#include "nice_lines.h"
using namespace std;
#define ll long long
#define ld long double
#define pii pair <int, int>
#define fi first
#define se second
#define mp make_pair
const ll LIM = 1e4, x0 = 2*LIM;
const ld EPS = 1e-9, inf = 1e18;
ll MAX_DEP = 32;
vector <int> va, vb;
set <pii> S;
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
void get(ld y){
int b = int(round(y+x0*LIM+LIM))%x0-LIM, a = int(round(y-b)/(ld)x0);
if (!S.count(mp(a, b))){
va.push_back(a);
vb.push_back(b);
S.insert(mp(a, b));
}
}
void dnc(int dep, ld l, ld r, ld fl, ld fr){
if (dep == MAX_DEP){
get((l+r)/2.0);
return;
}
ld mid = (l+r)/2.0;
if (fl == +inf) fl = query(x0, l);
if (fr == +inf) fr = query(x0, r);
ld fmid = query(x0, mid);
if (abs(2.0*fmid - (fl+fr)) <= EPS) return;
dnc(dep+1, l, mid, fl, fmid);
dnc(dep+1, mid, r, fmid, fr);
}
void solve(int subtask_id, int N){
if (N <= 3) MAX_DEP = 40;
va.clear();
vb.clear();
dnc(0, -2*LIM*(x0+1), 2*LIM*(x0+1), +inf, +inf);
the_lines_are(va, vb);
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
440 KB |
Output is correct |
2 |
Correct |
1 ms |
692 KB |
Output is correct |
3 |
Correct |
1 ms |
440 KB |
Output is correct |
4 |
Correct |
1 ms |
436 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
2 ms |
452 KB |
Output is correct |
2 |
Correct |
2 ms |
708 KB |
Output is correct |
3 |
Correct |
2 ms |
436 KB |
Output is correct |
4 |
Correct |
2 ms |
456 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
2 ms |
452 KB |
Output is correct |
2 |
Incorrect |
1 ms |
448 KB |
Incorrect |
3 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
28 ms |
688 KB |
Output is partially correct |
2 |
Partially correct |
27 ms |
696 KB |
Output is partially correct |
3 |
Partially correct |
33 ms |
704 KB |
Output is partially correct |
4 |
Partially correct |
28 ms |
460 KB |
Output is partially correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
10 ms |
688 KB |
Output is partially correct |
2 |
Partially correct |
12 ms |
452 KB |
Output is partially correct |
3 |
Partially correct |
13 ms |
456 KB |
Output is partially correct |
4 |
Partially correct |
12 ms |
448 KB |
Output is partially correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Partially correct |
28 ms |
688 KB |
Output is partially correct |
2 |
Partially correct |
27 ms |
696 KB |
Output is partially correct |
3 |
Partially correct |
33 ms |
704 KB |
Output is partially correct |
4 |
Partially correct |
28 ms |
460 KB |
Output is partially correct |
5 |
Partially correct |
10 ms |
688 KB |
Output is partially correct |
6 |
Partially correct |
12 ms |
452 KB |
Output is partially correct |
7 |
Partially correct |
13 ms |
456 KB |
Output is partially correct |
8 |
Partially correct |
12 ms |
448 KB |
Output is partially correct |
9 |
Partially correct |
39 ms |
448 KB |
Output is partially correct |
10 |
Partially correct |
35 ms |
688 KB |
Output is partially correct |
11 |
Partially correct |
37 ms |
700 KB |
Output is partially correct |
12 |
Partially correct |
38 ms |
696 KB |
Output is partially correct |