QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#246426 | #7678. The Game | fAKeZero# | WA | 1ms | 5732kb | C++17 | 2.5kb | 2023-11-10 20:13:23 | 2023-11-10 20:13:25 |
Judging History
answer
#include <bits/stdc++.h>
template<class _Tp = int>
_Tp read() {
_Tp ret = 0;
char ch = getchar(), sgn = 0;
while (!isdigit(ch)) sgn |= ch == '-', ch = getchar();
while (isdigit(ch)) ret = ret * 10 + ch - '0', ch = getchar();
return sgn ? -ret : ret;
}
const int kMaxN = 3e5 + 5;
int n, m, L;
long long dis;
int a[kMaxN], b[kMaxN];
std::vector<int> ans;
void clear() {
}
bool solve() {
ans.clear();
std::multiset<int> S;
for (int i = m + 1; i <= n; i++)
S.insert(a[i]);
int x = m, y = m;
while (x && a[x] == a[m]) x--;
x = m - x;
while (y <= n && a[y] == a[m]) y++;
y = y - m - 1;
int am = a[m];
int r = L - dis;
while (r > 0) {
// fprintf(stderr, "ROUND\n");
if (S.empty())
return false;
int c = *S.begin();
if (c == b[m])
return false;
if (c == am) {
// qiong tu mo lu le
// cong y li xi sheng x ge am
// printf("? x%d y%d r%d r+dis%d \n", x, y, r, r + dis);
if (y < r + dis || x > y)
return false;
else {
for (int i = 1; i <= x; i++)
ans.push_back(am);
for (int i = m - x + 1; i <= m; i++)
a[i]++;
for (int i = 1; i <= x; i++)
S.erase(S.begin());
am++;
}
continue;
}
ans.push_back(c);
S.erase(S.begin());
S.insert(c + 1);
S.erase(S.begin());
r--;
}
for (int i = 1; i <= m; i++)
while (a[i] < b[i])
ans.push_back(a[i]), a[i]++;
// print_ans();
// assert(ans.size() == m - n);
return true;
}
int main() {
int T = read();
while (T--) {
n = read(), m = read();
L = n - m;
for (int i = 1; i <= n; i++)
a[i] = read();
for (int i = 1; i <= m; i++)
b[i] = read();
std::sort(a + 1, a + n + 1, std::greater<int>());
std::sort(b + 1, b + m + 1, std::greater<int>());
dis = 0;
for (int i = 1; i <= m; i++) {
if (a[i] > b[i]) {
puts("-1");
goto end_of_loop;
}
dis += b[i] - a[i];
}
// fprintf(stderr, "dis %d?\n", dis);
if (dis > L) {
puts("-1");
goto end_of_loop;
}
if (solve()) {
printf("%d\n", L);
for (auto i : ans)
printf("%d ", i);
puts("");
} else
puts("-1");
end_of_loop:
clear();
}
}
/*
6
5 3
1 2 2 3 3
2 3 4
4 2
1 2 2 4
2 4
5 2
2 3 3 4 4
5 5
6 1
1 1 1 1 1 1
4
4 2
1 1 1 2
2 2
4 1
1 1 1 1
2
1
6 1
1 1 1 1 1 1
4
*/
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3576kb
input:
6 5 3 1 2 2 3 3 2 3 4 4 2 1 2 2 4 2 4 5 2 2 3 3 4 4 5 5 6 1 1 1 1 1 1 1 4 4 2 1 1 1 2 2 2 4 1 1 1 1 1 2
output:
2 1 3 -1 3 2 4 4 5 1 1 1 2 3 2 1 1 -1
result:
ok ok (6 test cases)
Test #2:
score: 0
Accepted
time: 1ms
memory: 3588kb
input:
7056 4 3 1 1 1 1 1 1 1 4 3 1 1 1 1 1 1 2 4 3 1 1 1 1 1 1 3 4 3 1 1 1 1 1 1 4 4 3 1 1 1 1 1 1 5 4 3 1 1 1 1 1 1 6 4 3 1 1 1 1 1 2 2 4 3 1 1 1 1 1 2 3 4 3 1 1 1 1 1 2 4 4 3 1 1 1 1 1 2 5 4 3 1 1 1 1 1 2 6 4 3 1 1 1 1 1 3 3 4 3 1 1 1 1 1 3 4 4 3 1 1 1 1 1 3 5 4 3 1 1 1 1 1 3 6 4 3 1 1 1 1 1 4 4 4 3 1 1...
output:
-1 1 1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 1 2 -1 -1 -1 1 1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...
result:
ok ok (7056 test cases)
Test #3:
score: 0
Accepted
time: 0ms
memory: 5732kb
input:
5880 4 2 1 1 1 1 1 1 4 2 1 1 1 1 1 2 4 2 1 1 1 1 1 3 4 2 1 1 1 1 1 4 4 2 1 1 1 1 1 5 4 2 1 1 1 1 1 6 4 2 1 1 1 1 1 7 4 2 1 1 1 1 2 2 4 2 1 1 1 1 2 3 4 2 1 1 1 1 2 4 4 2 1 1 1 1 2 5 4 2 1 1 1 1 2 6 4 2 1 1 1 1 2 7 4 2 1 1 1 1 3 3 4 2 1 1 1 1 3 4 4 2 1 1 1 1 3 5 4 2 1 1 1 1 3 6 4 2 1 1 1 1 3 7 4 2 1 1...
output:
-1 -1 2 1 2 -1 -1 -1 -1 2 1 1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 2 2 3 -1 -1 -1 2 1 1 2 2 1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 2 3 4 -1 -1 -1 2 1 1 2 3 1 -1 -1 -1 2 1 2 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...
result:
ok ok (5880 test cases)
Test #4:
score: -100
Wrong Answer
time: 0ms
memory: 3644kb
input:
2640 4 1 1 1 1 1 1 4 1 1 1 1 1 2 4 1 1 1 1 1 3 4 1 1 1 1 1 4 4 1 1 1 1 1 5 4 1 1 1 1 1 6 4 1 1 1 1 1 7 4 1 1 1 1 1 8 4 1 1 1 1 2 1 4 1 1 1 1 2 2 4 1 1 1 1 2 3 4 1 1 1 1 2 4 4 1 1 1 1 2 5 4 1 1 1 1 2 6 4 1 1 1 1 2 7 4 1 1 1 1 2 8 4 1 1 1 1 3 1 4 1 1 1 1 3 2 4 1 1 1 1 3 3 4 1 1 1 1 3 4 4 1 1 1 1 3 5 4...
output:
-1 -1 3 1 1 2 3 1 2 3 -1 -1 -1 -1 -1 -1 3 1 1 2 3 1 2 3 3 2 3 4 -1 -1 -1 -1 -1 3 1 1 2 3 1 1 3 3 1 3 4 3 3 4 5 -1 -1 -1 -1 -1 3 1 1 2 3 1 1 4 3 1 4 5 3 4 5 6 -1 -1 -1 -1 -1 3 1 1 2 3 1 1 5 3 1 5 6 3 5 6 7 -1 -1 -1 -1 -1 3 1 1 2 3 1 1 6 3 1 6 7 -1 -1 -1 -1 -1 -1 3 1 1 2 3 1 1 7 ...
result:
wrong answer Jury has answer but participant has not (test case 67)