QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#624394#8022. WalkerTankYoung#WA 0ms3948kbC++141.0kb2024-10-09 15:45:012024-10-09 15:45:02

Judging History

This is the latest submission verdict.

  • [2024-10-09 15:45:02]
  • Judged
  • Verdict: WA
  • Time: 0ms
  • Memory: 3948kb
  • [2024-10-09 15:45:01]
  • Submitted

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));
    ans = min(ans, min(p2 / v2, (n - p1) / v1));
    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(10)<< 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: 3948kb

input:

2
10000.0 1.0 0.001 9999.0 0.001
4306.063 4079.874 0.607 1033.423 0.847

output:

5001000.0000000000
3827.8370013755

result:

ok 2 numbers

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 3884kb

input:

1
10.0 1.0 10.0 9.0 0.1

output:

0.9000000000

result:

wrong answer 1st numbers differ - expected: '1.1000000', found: '0.9000000', error = '0.1818182'