QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#725356 | #8022. Walker | nnk | WA | 11ms | 3944kb | C++20 | 2.1kb | 2024-11-08 17:15:07 | 2024-11-08 17:15:07 |
Judging History
answer
#include<iostream>
#include<vector>
#include<algorithm>
#include<set>
#include<iomanip>
#include<queue>
#include<math.h>
#include<map>
#include<bitset>
#include<numeric>
#include <cstring>
#include<array>
#include <string>
#include<unordered_set>
#include<unordered_map>
using namespace std;
#define int long long
//#define endl "\n"
#define mod 1000000007ll
#define IOS ios::sync_with_stdio(false),cin.tie(nullptr)
#define syy return
const double pi = acos(-1.0);
using ll = long long;
using pii = pair<int, int>;
using vint = vector<int>;
using vll = vector<ll>;
using vvint = vector<vint>;
using vpo = vector<pii>;
using tup = tuple<int, int, int>;
using vbl = vector<bool>;
constexpr int N = 100000, M = 2000006;//开足够的空间 注意无向图的双向边边数*2
constexpr ll inf = 1e16;
long double eps = 1e-7;
set<int> all;
void solve()
{
double p1, v1, p2, v2, ans, n;
cin >> n >> p1 >> v1 >> p2 >> v2;
if (p1 -p2> eps) {
swap(p1, p2);
swap(v1, v2);
}
//一个人走完全程
ans = (min(p1, n - p1) + n) / v1;
ans = min(ans, (min(p2, n - p2) + n) / v2);
//相反方向走
ans = min(ans, (n + p1 + (n - p2)) / (v1 + v2));
double tt = min(max((p2 + p1) / v1, (n - p2) / v2), max((n - p1 + n - p2) / v2, p1 / v1)), x, x2;
ans = min(ans, tt);
//相对方向走
tt = (n + p2 - p1) / (v1 + v2);
if (tt * v1 - p1 < eps || tt * v2-(n - p2) <eps );
else ans = min(ans, tt);
//相同方向走
x = (2 * n * v1 + p1 * v2 - p2 * v1) / (v1 + 2 * v2);
if (x - p1>=eps && x -p2<= eps)
ans = min(ans, (2 * x - p1) / v1);
ans = min(ans, max((p2 + p2 - p1) / v1, (n - p2) / v2));
x2 = (n * v1 + p2 * v1 - p1 * v2) / (2 * v1 + v2);
if (x2 -p1>= eps && x2-p2 <= eps)
ans = min(ans, (n + p2 - 2 * x2) / v2);
ans = min(ans, max((p2 - p1 + n - p1) / v2, p1 / v1));
cout << setiosflags(ios::fixed) << setprecision(10) << ans << endl;
}
signed main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int T = 1;
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: 3804kb
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: 0
Accepted
time: 0ms
memory: 3896kb
input:
1 10.0 1.0 10.0 9.0 0.1
output:
1.1000000000
result:
ok found '1.1000000', expected '1.1000000', error '0.0000000'
Test #3:
score: 0
Accepted
time: 0ms
memory: 3916kb
input:
1 10.0 8.0 10.0 9.0 0.1
output:
1.2000000000
result:
ok found '1.2000000', expected '1.2000000', error '0.0000000'
Test #4:
score: 0
Accepted
time: 0ms
memory: 3944kb
input:
1 10.0 8.0 0.1 9.0 10
output:
1.1000000000
result:
ok found '1.1000000', expected '1.1000000', error '0.0000000'
Test #5:
score: 0
Accepted
time: 0ms
memory: 3852kb
input:
1 10.0 2.0 0.1 3.0 10
output:
1.3000000000
result:
ok found '1.3000000', expected '1.3000000', error '0.0000000'
Test #6:
score: 0
Accepted
time: 0ms
memory: 3912kb
input:
1 10.0 9.0 0.1 8.0 10.0
output:
1.2000000000
result:
ok found '1.2000000', expected '1.2000000', error '0.0000000'
Test #7:
score: 0
Accepted
time: 0ms
memory: 3856kb
input:
1 10.0 4.0 0.1 6.0 0.1
output:
60.0000000000
result:
ok found '60.0000000', expected '60.0000000', error '0.0000000'
Test #8:
score: 0
Accepted
time: 0ms
memory: 3836kb
input:
1 10.0 4.5 0.1 6.0 0.1
output:
57.5000000000
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.5000000000
result:
ok found '6.5000000', expected '6.5000000', error '0.0000000'
Test #10:
score: 0
Accepted
time: 0ms
memory: 3896kb
input:
1 10.0 3.0 2.0 7.0 1.0
output:
4.6000000000
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.6666666667
result:
ok found '3.6666667', expected '3.6666667', error '0.0000000'
Test #12:
score: 0
Accepted
time: 0ms
memory: 3832kb
input:
1 10.0 1.0 1.0 9.0 1.0
output:
6.0000000000
result:
ok found '6.0000000', expected '6.0000000', error '0.0000000'
Test #13:
score: 0
Accepted
time: 0ms
memory: 3708kb
input:
1 10000.0 1.0 0.001 1.0 0.001
output:
9999000.0000000000
result:
ok found '9999000.0000000', expected '9999000.0000000', error '0.0000000'
Test #14:
score: 0
Accepted
time: 1ms
memory: 3856kb
input:
1 10.0 5.0 1.0 5.0 1.5
output:
5.0000000000
result:
ok found '5.0000000', expected '5.0000000', error '0.0000000'
Test #15:
score: -100
Wrong Answer
time: 11ms
memory: 3820kb
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.8370013755 7999.3649921507 12559.3358024691 15415.5444617785 2637.6985195155 9931.0415175376 934.4943011398 4326.9490616622 5754.0328898744 2847.4271570014 10975.3236282195 2902.1791044776 24531.5363636364 6278.1035548686 1030.0000000000 10734.3956442831 1005.0770288858 24249.7467811159 9878.00...
result:
wrong answer 4th numbers differ - expected: '15371.5507020', found: '15415.5444618', error = '0.0028620'