QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#624369 | #8022. Walker | TankYoung# | WA | 92ms | 3968kb | C++14 | 982b | 2024-10-09 15:41:07 | 2024-10-09 15:41:11 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define double long double
double walk(double pos, double l, double r, double v)
{
double ret = (r - l) / v;
ret += min((r - pos) / v, (pos - l) / v);
return ret;
}
void solve()
{
double n, p1, p2, v1, v2;
cin >> n >> p1 >> v1 >> p2 >> v2;
if (p1 > p2)
{
swap(p1, p2); swap(v1, v2);
}
double ans = min(walk(p1, 0.0000000, n, v1), walk(p2, 0.0000000, n, v2));
double l = p1, r = p2, tmp1, tmp2;
double ss;
for (int i = 1; i <= 400; i++)
{
double mid = (l + r) / 2.0000000; ss = mid;
tmp1 = walk(p1, 0, mid, v1); tmp2 = walk(p2, mid, n, v2);
if (tmp1 >= tmp2) r = mid;
else l = mid;
}
ans = min(ans, max(walk(p1, 0, ss, v1), walk(p2, ss, n, v2)));
cout <<fixed<<setprecision(7)<< ans << '\n';
}
int main()
{
int T;
cin >> T;
while (T--)
{
solve();
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3896kb
input:
2 10000.0 1.0 0.001 9999.0 0.001 4306.063 4079.874 0.607 1033.423 0.847
output:
5001000.0000000 3827.8370014
result:
ok 2 numbers
Test #2:
score: 0
Accepted
time: 0ms
memory: 3840kb
input:
1 10.0 1.0 10.0 9.0 0.1
output:
1.1000000
result:
ok found '1.1000000', expected '1.1000000', error '0.0000000'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3900kb
input:
1 10.0 8.0 10.0 9.0 0.1
output:
1.2000000
result:
ok found '1.2000000', expected '1.2000000', error '0.0000000'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3852kb
input:
1 10.0 8.0 0.1 9.0 10
output:
1.1000000
result:
ok found '1.1000000', expected '1.1000000', error '0.0000000'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3968kb
input:
1 10.0 2.0 0.1 3.0 10
output:
1.3000000
result:
ok found '1.3000000', expected '1.3000000', error '0.0000000'
Test #6:
score: 0
Accepted
time: 0ms
memory: 3860kb
input:
1 10.0 9.0 0.1 8.0 10.0
output:
1.2000000
result:
ok found '1.2000000', expected '1.2000000', error '0.0000000'
Test #7:
score: 0
Accepted
time: 0ms
memory: 3896kb
input:
1 10.0 4.0 0.1 6.0 0.1
output:
60.0000000
result:
ok found '60.0000000', expected '60.0000000', error '0.0000000'
Test #8:
score: 0
Accepted
time: 0ms
memory: 3964kb
input:
1 10.0 4.5 0.1 6.0 0.1
output:
57.5000000
result:
ok found '57.5000000', expected '57.5000000', error '0.0000000'
Test #9:
score: 0
Accepted
time: 0ms
memory: 3856kb
input:
1 10.0 1.0 1.0 8.0 1.0
output:
6.5000000
result:
ok found '6.5000000', expected '6.5000000', error '0.0000000'
Test #10:
score: 0
Accepted
time: 0ms
memory: 3948kb
input:
1 10.0 3.0 2.0 7.0 1.0
output:
4.6000000
result:
ok found '4.6000000', expected '4.6000000', error '0.0000000'
Test #11:
score: 0
Accepted
time: 0ms
memory: 3896kb
input:
1 10.0 6.0 2.0 7.0 1.0
output:
3.6666667
result:
ok found '3.6666667', expected '3.6666667', error '0.0000000'
Test #12:
score: 0
Accepted
time: 0ms
memory: 3716kb
input:
1 10.0 1.0 1.0 9.0 1.0
output:
6.0000000
result:
ok found '6.0000000', expected '6.0000000', error '0.0000000'
Test #13:
score: 0
Accepted
time: 0ms
memory: 3908kb
input:
1 10000.0 1.0 0.001 1.0 0.001
output:
9999000.0000000
result:
ok found '9999000.0000000', expected '9999000.0000000', error '0.0000000'
Test #14:
score: 0
Accepted
time: 0ms
memory: 3908kb
input:
1 10.0 5.0 1.0 5.0 1.5
output:
5.0000000
result:
ok found '5.0000000', expected '5.0000000', error '0.0000000'
Test #15:
score: -100
Wrong Answer
time: 92ms
memory: 3852kb
input:
10000 4306.063 4079.874 0.607 1033.423 0.847 8967.336 8026.500 0.398 283.019 0.876 9568.147 4481.616 0.405 800.114 0.684 9867.264 6184.040 0.312 9853.164 0.641 3344.364 730.612 0.539 1305.868 0.947 9336.180 3672.113 0.773 432.686 0.312 1468.243 59.762 0.840 1438.446 0.827 1355.133 1096.314 0.373 109...
output:
3827.8370014 7999.3649922 12559.3358025 15415.5444618 2637.6985195 9931.0415175 934.4943011 4326.9490617 5754.0328899 2847.4271570 10975.3236282 2902.1791045 24531.5363636 6278.1035549 1030.0000000 10734.3956443 1005.0770289 24249.7467811 9878.0099458 22899.2592593 12409.8977778 33365.4761905 3153.0...
result:
wrong answer 4th numbers differ - expected: '15371.5507020', found: '15415.5444618', error = '0.0028620'