QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#226761 | #5152. Circular Caramel Cookie | Fyind# | WA | 0ms | 3880kb | C++23 | 1.6kb | 2023-10-26 15:45:32 | 2023-10-26 15:45:33 |
Judging History
answer
#include <bits/stdc++.h>
typedef long long ll;
using namespace std;
bool check(ll x, ll s, ll dx, ll dy) {
// cout << dx << ' ' << dy << endl;
ll cnt = 0;
for (ll i = 1; (2 * i - dx) * (2 * i - dx) <= x; ++i) {
ll l = 0, r = sqrt(x);
ll res = x - (2 * i - dx) * (2 * i - dx);
while (l <= r) {
ll mid = (l + r) >> 1;
if ((2 * mid + dy) * (2 * mid + dy) <= res)
l = mid + 1;
else
r = mid - 1;
}
// cout << l << ',' << i << ',' << x << endl;
// cout << res << endl;
cnt += ((l - 1) * 2 + dy) * (1 + !(dx && i == 1));//, cout << cnt << '!';
}
// cout << x << ':' << cnt << ',' << s << endl;
return cnt < s;
}
int main() {
ll s;
cin >> s;
ll ans = 0x3f3f3f3f;
{
ll ss = (s + 3) / 4 * 4;
// cout << s << endl;
ll l = 0, r = 20 * ss;
while (l <= r) {
ll mid = (l + r) / 2;
if(check(mid, ss, 0, 0))
l = mid + 1;
else
r = mid - 1;
}
ans = min(ans, l);
}
// {
// ll l = 0, r = 20 * s;
// while (l <= r) {
// ll mid = (l + r) / 2;
// if(check(mid, s, 1, 1))
// l = mid + 1;
// else
// r = mid - 1;
// }
// // cout << l << endl;
// ans = min(ans, l);
// }
// {
// ll l = 0, r = 20 * s;
// while (l <= r) {
// ll mid = (l + r) / 2;
// if(check(mid, s, 1, 0))
// l = mid + 1;
// else
// r = mid - 1;
// }
// // cout << l << endl;
// ans = min(ans, l);
// }
// cout << ans << endl;
long double l = 0, r = ans / 4;
while (r - l > 1e-10) {
long double mid = (l + r)/ 2;
if (mid * mid <= ans / 4)
l = mid;
else
r = mid;
}
cout << fixed << setprecision(10) << l << '\n';
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3880kb
input:
11
output:
2.2360679774
result:
ok found '2.2360680', expected '2.2360680', error '0.0000000'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3804kb
input:
59
output:
4.9999999999
result:
ok found '5.0000000', expected '5.0000000', error '0.0000000'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3864kb
input:
1
output:
1.4142135623
result:
ok found '1.4142136', expected '1.4142136', error '0.0000000'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3860kb
input:
2
output:
1.4142135623
result:
ok found '1.4142136', expected '1.4142136', error '0.0000000'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3660kb
input:
3
output:
1.4142135623
result:
ok found '1.4142136', expected '1.4142136', error '0.0000000'
Test #6:
score: -100
Wrong Answer
time: 0ms
memory: 3808kb
input:
4
output:
1.4142135623
result:
wrong answer 1st numbers differ - expected: '2.2360680', found: '1.4142136', error = '0.3675445'