QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#639995 | #9462. Safest Buildings | rogi52 | AC ✓ | 1ms | 3808kb | C++20 | 1.8kb | 2024-10-14 01:24:12 | 2024-10-14 01:24:12 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define rep(i, n) for(int i = 0; i < (n); i++)
#define srep(i, s, t) for(int i = (s); i < (t); i++)
#define len(x) ((int)(x).size())
#define all(x) (x).begin(), (x).end()
template < class T > bool chmin(T& a, T b) { if(a > b) { a = b; return true; } return false; }
template < class T > bool chmax(T& a, T b) { if(a < b) { a = b; return true; } return false; }
using i64 = long long;
using f64 = long double;
i64 floor_div(const i64 n, const i64 d) { assert(d != 0); return n / d - static_cast<i64>((n ^ d) < 0 && n % d != 0); }
i64 ceil_div(const i64 n, const i64 d) { assert(d != 0); return n / d + static_cast<i64>((n ^ d) >= 0 && n % d != 0); }
void out(vector<int> I) {
const int m = I.size();
cout << m << "\n";
rep(i, m) cout << I[i] + 1 << " \n"[i == m - 1];
return;
}
void solve() {
int n, R, r; cin >> n >> R >> r; R -= r;
vector<int> x(n), y(n);
rep(i, n) cin >> x[i] >> y[i];
vector<int> d(n);
rep(i, n) d[i] = x[i] * x[i] + y[i] * y[i];
if(r <= R) {
vector<int> ALL_IN;
rep(i, n) if(d[i] <= (R - r) * (R - r)) ALL_IN.push_back(i);
if(not ALL_IN.empty()) { out(ALL_IN); return; }
} else {
vector<int> ALL_CONTAIN;
rep(i, n) if(d[i] <= (r - R) * (r - R)) ALL_CONTAIN.push_back(i);
if(not ALL_CONTAIN.empty()) { out(ALL_CONTAIN); return; }
}
const int d_min = *min_element(d.begin(), d.end());
if((R + r) * (R + r) <= d_min) {
vector<int> I(n);
rep(i, n) I[i] = i;
out(I);
return;
} else {
vector<int> argmin;
rep(i, n) if(d[i] == d_min) argmin.push_back(i);
out(argmin);
return;
}
}
int main() {
cin.tie(0)->sync_with_stdio(0);
int T; cin >> T;
rep(_, T) solve();
}
这程序好像有点Bug,我给组数据试试?
詳細信息
Test #1:
score: 100
Accepted
time: 0ms
memory: 3612kb
input:
2 3 10 5 3 4 3 5 3 6 3 10 4 -7 -6 4 5 5 4
output:
1 1 2 2 3
result:
ok 5 tokens
Test #2:
score: 0
Accepted
time: 1ms
memory: 3808kb
input:
100 6 100 50 42 -31 -66 7 13 84 94 13 51 -14 -18 9 12 100 50 -78 56 -56 -64 -22 54 -41 14 -14 55 21 -83 75 21 -51 56 -31 74 -34 79 22 -37 1 -12 14 100 50 15 71 -44 41 -56 78 -48 22 42 -2 -70 28 51 -34 49 -31 -36 67 63 70 34 9 27 -33 36 -93 -52 -19 8 100 14 21 89 67 60 -12 -3 24 -37 -51 14 -30 8 -75 ...
output:
1 6 1 12 1 11 4 3 4 5 6 7 1 4 6 8 9 12 13 1 1 6 2 4 5 7 13 14 7 1 3 4 5 6 7 9 1 11 9 1 2 3 4 5 6 7 8 9 1 29 1 5 1 29 47 1 2 3 4 5 6 7 9 10 11 12 14 17 18 19 21 22 24 25 26 27 28 30 31 32 33 34 35 36 37 38 39 40 41 43 44 45 46 47 48 50 51 52 53 54 55 56 2 21 29 20 1 5 6 7 10 13 14 18 21 25 26 30 33 3...
result:
ok 1674 tokens
Extra Test:
score: 0
Extra Test Passed