QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#716173 | #9574. Strips | ucup-team2179# | WA | 26ms | 3620kb | C++20 | 1.6kb | 2024-11-06 14:36:38 | 2024-11-06 14:36:39 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
#define pii pair<int, int>
#define ll long long
using namespace std;
int n, m, k, w;
void solve() {
cin >> n >> m >> k >> w;
bool flag = 1;
vector<int> blk, red, ans;
for (int i = 1; i <= n; i++){
int x;
cin >> x;
red.push_back(x);
}
for(int i = 1; i <= m; i++){
int x;
cin >> x;
blk.push_back(x);
}
blk.push_back(0);
blk.push_back(w + 1);
sort(red.begin(), red.end());
sort(blk.begin(), blk.end());
int j = 0;
for (int i = 1; i < blk.size(); i++){
int L = blk[i-1] + 1, R = blk[i];
vector<int> now, tmp;
while (j < red.size() && red[j] < blk[i])
now.push_back(red[j]), j++;
int l = L, space = 0;
for(auto x : now){
if(l > x)
continue;
space += (x - l);
l = x + k;
tmp.push_back(x);
}
if(l > R && l - R > space){
flag = 0;
break;
}
space = l - R;
for (int t = tmp.size() - 1; t >= 0; t--){
ans.push_back(tmp[t] - space);
space -= min(space, tmp[t] - tmp[t - 1] - k);
}
}
if(!flag) cout << "-1\n";
else {
sort(ans.begin(), ans.end());
cout << ans.size() << '\n';
for(auto x : ans)
cout << x << ' ';
cout << '\n';
}
}
signed main() {
ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
int t = 1;
cin >> t;
while (t--)
solve();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3620kb
input:
4 5 2 3 16 7 11 2 9 14 13 5 3 2 4 11 6 10 2 1 11 2 1 2 6 1 5 3 2 1 2 6 1 5 2
output:
4 2 7 10 14 -1 2 1 5 -1
result:
ok ok 4 cases (4 test cases)
Test #2:
score: -100
Wrong Answer
time: 26ms
memory: 3608kb
input:
11000 3 8 2 53 32 3 33 35 19 38 20 1 30 10 6 7 10 1 42 3 14 4 36 28 40 22 17 20 12 41 27 7 1 19 13 9 6 6 13 78 55 76 53 32 54 58 62 45 21 4 7 61 8 7 3 68 9 26 54 31 22 3 38 65 34 16 58 47 52 29 53 5 8 4 33 33 5 30 6 15 27 12 9 28 19 2 13 10 6 1 2 48 8 12 48 1 41 31 40 7 6 7 61 20 19 30 52 49 17 40 3...
output:
2 4 33 7 3 6 16 26 28 36 40 3 32 48 66 8 3 13 22 26 31 44 55 66 3 5 15 30 6 1 8 12 38 41 47 4 17 30 39 55 2 52 84 1 31 1 22 1 62 5 24 33 43 48 64 2 16 57 3 11 20 31 3 3 18 33 3 25 30 79 3 3 28 60 4 1 11 21 33 2 54 66 3 50 60 69 3 50 67 79 1 81 4 4 11 16 43 5 3 14 17 36 50 2 1...
result:
wrong answer There is no stripe covering red cell 3 (test case 1)