QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#734775#9574. StripsUfowoqqqoWA 58ms3840kbC++141.8kb2024-11-11 15:03:012024-11-11 15:03:09

Judging History

你现在查看的是最新测评结果

  • [2024-11-11 15:03:09]
  • 评测
  • 测评结果:WA
  • 用时:58ms
  • 内存:3840kb
  • [2024-11-11 15:03:01]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int n,m,k,w;
int a[N],b[N];
int cur;
vector<int>res;
bool solve(int l,int r)
{
    if(l>r)return true;
    vector<int>v;
    while(cur<=n&&a[cur]>=l&&a[cur]<=r)
    {
        v.push_back(a[cur]);
        cur++;
    }
    if(v.empty())return true;
    int x=v.front(),y=v.back();
    int len=y-x+1;
    int cnt=(len-1)/k+1;
    if(l+cnt*k-1>=y&&l+cnt*k-1<=r)
    {
        for(int i=0;i<cnt;i++)
        {
            res.push_back(l);
            l+=k;
        }
        return true;
    }
    if(r-cnt*k+1<=x&&r-cnt*k+1>=l)
    {
        for(int i=0;i<cnt;i++)
        {
            res.push_back(r-k+1);
            r-=k;
        }
        return true;
    }
    if(x+cnt*k-1<=r)
    {
        for(int i=0;i<cnt;i++)
        {
            res.push_back(x);
            x+=k;
        }
        return true;
    }
    if(y-cnt*k+1>=l)
    {
        for(int i=0;i<cnt;i++)
        {
            res.push_back(y-k+1);
            y-=k;
        }
        return true;
    }
    return false;
}
bool work()
{
    sort(a+1,a+n+1);
    sort(b+1,b+m+1);
    res.clear();
    cur=1;
    if(!solve(1,b[1]-1))return false;
    for(int i=1;i<m;i++)
        if(!solve(b[i]+1,b[i+1]-1))return false;
    if(!solve(b[m]+1,w))return false;
    return true;
}
int main()
{
    int t;
    cin>>t;
    while(t--)
    {
        cin>>n>>m>>k>>w;
        for(int i=1;i<=n;i++)
            cin>>a[i];
        for(int i=1;i<=m;i++)
            cin>>b[i];
        if(!work())cout<<-1<<endl;
        else
        {
            cout<<res.size()<<endl;
            for(auto &x:res)
                cout<<x<<" ";
            cout<<endl;
        }
    }
    return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 3840kb

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
1 6 9 14 
-1
2
1 4 
-1

result:

ok ok 4 cases (4 test cases)

Test #2:

score: -100
Wrong Answer
time: 58ms
memory: 3792kb

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
2 32 
17
3 4 14 22 28 29 30 31 32 33 34 35 36 37 38 39 40 
3
22 46 66 
9
1 4 7 22 25 30 38 54 65 
3
3 14 30 
20
1 3 5 7 9 11 13 15 17 19 21 23 25 27 29 31 41 43 45 47 
4
17 27 34 47 
3
52 63 74 
1
27 
1
9 
1
62 
14
24 43 41 39 37 35 33 48 50 52 54 56 58 60 
2
4 31 
3
11 19 29 
3
3 16 33 
7
30 29 2...

result:

wrong answer Integer parameter [name=c] equals to 17, violates the range [-1, 7] (test case 2)