QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#648636 | #9223. Data Determination | ucup-team963# | WA | 103ms | 24576kb | C++14 | 2.8kb | 2024-10-17 19:44:58 | 2024-10-17 19:44:59 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define debug(x) cerr << #x << ": " << x << '\n';
#define bd cerr << "----------------------" << el;
#define el '\n'
#define rep(i, a, b) for (int i = (a); i <= (b); i++)
#define lop(i, a, b) for (int i = (a); i < (b); i++)
#define dwn(i, a, b) for (int i = (a); i >= (b); i--)
#define cmax(a, b) a = max(a, b)
#define cmin(a, b) a = min(a, b)
#define db double
#define ceil(a, b) (((a) + (b) - 1) / (b))
typedef long long LL;
typedef pair<int, int> PII;
constexpr int N = 2e6 + 10, md = 1e9 + 7;
constexpr int INF = 0x3f3f3f3f;
int n, m, k;
int a[N];
void yes()
{
cout << "TAK" << el;
}
void no()
{
cout << "NIE" << el;
}
void add(int &x, int val, int &y)
{// x尝试从y中获取val个
int now = min(val, y);
x += now;
y -= now;
return ;
}
void solve()
{
cin >> n >> k >> m;
rep(i, 1, n)
{
cin >> a[i];
}
sort(a + 1, a + n + 1);
int hk = k / 2;
if(k & 1)
{//奇数
bool ok = false;
hk = k / 2;
rep(i, 1, n)
{
if(a[i] == m)
{
int l = i - 1;
int r = n - i;
if(l >= hk && r >= hk)
{
yes();
return ;
}
}
}
no();
return ;
}
// 偶数
map<int, int> cnt;
rep(i, 1, n)
{
cnt[a[i]] ++;
}
int now = 0;
map<int, int> sum;
for(auto &[k, v] : cnt)
{
sum[k] = now;
now += v;
}
for(auto &[x, v] : cnt)
{
int y = 2 * m - x;
auto it = cnt.find(y);
if(it == cnt.end() || it->first != y)
continue;
//找到了y
if(y < x)
break;
hk --;
if(y > x)
{
int L = sum[x] + v - 1;
//左边有多少个数
int R = n - sum[y] - 1;
if(L >= hk && R >= hk)
{
yes();
return ;
}
}
else {
assert(y == x);
if(v == 1)
continue;
int L = sum[x];
int R = n - sum[x] - v;
int rest = v - 2;
if(L < hk)
{
add(L, hk - L, rest);
}
if(R < hk)
{
add(R, hk - R, rest);
}
if(L >= hk && R >= hk)
{
yes();
return ;
}
}
}
no();
}
signed main()
{
cin.tie(0)->sync_with_stdio(false);
cout.tie(0);
int T;
cin >> T;
while(T --)
{
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3684kb
input:
3 6 4 42 41 43 41 57 41 42 4 2 4 1 2 5 8 7 5 57 101 2 42 5 57 7 13
output:
TAK NIE NIE
result:
ok 3 lines
Test #2:
score: 0
Accepted
time: 103ms
memory: 24576kb
input:
1 200000 2 482043846 410684388 380438852 309193412 468460689 586281084 680820569 266819813 639025900 488292166 503516930 532292185 618277661 728546481 628339224 673945619 471325257 372807753 325778059 372151033 548358519 276494019 336701079 320784795 377493322 385262271 621712987 349634764 668994576...
output:
NIE
result:
ok single line: 'NIE'
Test #3:
score: -100
Wrong Answer
time: 41ms
memory: 5532kb
input:
10 20000 3530 502140211 367996343 553577602 581694419 435810361 532394401 431613294 485360190 608191058 506969937 531905607 429252296 360241499 519031654 250454430 478548102 753825992 450326073 603766643 566036856 511634983 416622101 753825992 753825992 380511285 390746506 436237616 342529443 878920...
output:
TAK TAK TAK NIE TAK NIE NIE NIE TAK TAK
result:
wrong answer 1st lines differ - expected: 'NIE', found: 'TAK'