QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#606379 | #9434. Italian Cuisine | LeonaRaging | WA | 2ms | 6680kb | C++23 | 2.0kb | 2024-10-03 02:21:44 | 2024-10-03 02:21:44 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define db(val) "[" #val " = " << (val) << "] "
const int maxn = 2e5 + 4;
using T = long long;
using i128 = __int128;
T R;
struct pt {
T x, y;
pt (T x = 0, T y = 0): x(x), y(y) {}
pt operator - (pt o) { return pt(x - o.x, y - o.y);}
bool operator == (pt o) { return x == o.x && y == o.y;}
bool operator != (pt o) {return x != o.x || y != o.y;}
};
T dot(pt p, pt q) {return p.x * q.x + p.y * q.y;}
T cross(pt p, pt q) {return p.x * q.y - p.y * q.x;}
T abs(pt p) {return p.x * p.x + p.y * p.y;}
T orient(pt a, pt b, pt c) {return cross(b - a, c - a);}
struct line {
pt v; T c;
line(pt p, pt q): v(q - p), c(cross(v, p)) {};
bool cmpProj(pt p, pt q) {
return dot(v, p) < dot(v, q);
}
T side(pt p) {return cross(v, p) - c;}
T dist(pt p) {return (abs(side(p)) * abs(side(p)) - 1) / abs(v);}
};
T segPoint(pt a, pt b, pt p) {
if (a != b) {
line l(a, b);
i128 u = abs(l.side(p)), v = abs(l.v), r = R;
u = (u * u - 1) / v;
r *= r;
return u > r;
}
return min(abs(p - a), abs(p - b)) > R * R;
}
int n;
pt C, a[maxn];
void Solve() {
cin >> n >> C.x >> C.y >> R;
for (int i = 1; i <= n; i++)
cin >> a[i].x >> a[i].y;
for (int i = n + 1; i <= 2 * n; i++)
a[i] = a[i - n];
int j = 1;
T res = 0, cur = 0;
for (int i = 1; i <= n; i++) {
// clog << segPoint()
while (orient(a[i], a[j + 1], C) > 0 && segPoint(a[i], a[j + 1], C)) {
cur += abs(cross(a[i], a[j]) + cross(a[j], a[j + 1]) + cross(a[j + 1], a[i]));
j++;
}
res = max(res, cur);
// clog << i << ' ' << j << ' ' << cur << endl;
if (i < j) cur -= abs(cross(a[i], a[i + 1]) + cross(a[i + 1], a[j]) + cross(a[j], a[i]));
else j = i + 1;
}
cout << res << '\n';
// line l(a[3], a[4]);
// clog << abs(l.v);
// clog << segPoint(a[3], a[4], C);
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
int t; cin >> t;
while (t--) {
Solve();
}
}
详细
Test #1:
score: 0
Wrong Answer
time: 2ms
memory: 6680kb
input:
3 5 1 1 1 0 0 1 0 5 0 3 3 0 5 6 2 4 1 2 0 4 0 6 3 4 6 2 6 0 3 4 3 3 1 3 0 6 3 3 6 0 3
output:
5 12 0
result:
wrong answer 2nd numbers differ - expected: '24', found: '12'