QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#717118#9574. StripsKJJD#AC ✓58ms6784kbC++203.1kb2024-11-06 16:57:542024-11-06 16:57:55

Judging History

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

  • [2024-11-06 16:57:55]
  • 评测
  • 测评结果:AC
  • 用时:58ms
  • 内存:6784kb
  • [2024-11-06 16:57:54]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
int n, m, k, w;
const int maxn = 200005;
int f[maxn], g[maxn];
int a[maxn], b[maxn];
int ans[maxn];
inline int read()
{
    int ret = 0;
    char ch = getchar();
    bool flg = 0;
    while (!isdigit(ch))
        flg ^= !(ch ^ '-'), ch = getchar();
    while (isdigit(ch))
        ret = (ret << 3) + (ret << 1) + ch - 48, ch = getchar();
    return flg ? -ret : ret;
}
int find_bad(int x)
{
    int L = 0, R = m;
    while (L <= R)
    {
        int mid = (R - L >> 1) + L;
        if (b[mid] <= x)
            L = mid + 1;
        else
            R = mid - 1;
    }
    return b[R];
}
int find_good(int x)
{
    int L = 0, R = n;
    while (L <= R)
    {
        int mid = (R - L >> 1) + L;
        if (a[mid] < x)
            L = mid + 1;
        else
            R = mid - 1;
    }
    return R;
}
void solve()
{
    n = read(), m = read(), k = read(), w = read();
    for (int i = 1; i <= n; i++)
        a[i] = read();
    for (int i = 1; i <= m; i++)
        b[i] = read();
    // b[++m] = 0;
    b[++m] = w + 1;
    sort(a + 1, a + 1 + n);
    sort(b + 1, b + 1 + m);
    f[0] = 0;
    bool gg = 0;
    for (int i = 1; i <= n; i++)
    {
        int R = a[i], L = a[i] - k + 1;
        int bad = find_bad(R);
        if (bad < L)
        {
            int god = find_good(L);
            if(f[god]<L){
                g[i] = god;
                f[i] = R;
            }
            else{
                L=f[god]+1;
                R=L+k-1;
                int bad__=find_bad(R);
                if(bad__>=L){
                    gg=1;
                    break;
                }
                f[i]=R;
                g[i]=god;
            }
            
        }
        else
        {
            L = bad + 1;
            R = L + k - 1;
            int bad_ = find_bad(R);
            if (bad_ != bad)
            {
                gg = 1;
                break;
            }
            int god = find_good(L);
            if(f[god]<L){
                g[i] = god;
                f[i] = R;
            }
            else{
                L=f[god]+1;
                R=L+k-1;
                int bad__=find_bad(R);
                if(bad__>=L){
                    gg=1;
                    break;
                }
                f[i]=R;
                g[i]=god;
            }
            
        }
    }
    if (gg)
    {
        printf("-1\n");
        return;
    }
    // for (int i = 1; i <= n; i++)
    //     printf("%d %d %d\n", i, f[i], g[i]);
    int tot = 0;
    for (int i = n; i; i = g[i])
    {
        ans[++tot] = f[i] - k + 1;
    }
    printf("%d\n", tot);
    for (int i = 1; i <= tot; i++)
    {
        printf("%d%c", ans[i], i == tot ? '\n' : ' ');
    }
}
int main()
{
#ifdef LOCAL
    freopen("data.in", "r", stdin);
    freopen("data.out", "w", stdout);
#endif
    // ios::sync_with_stdio(false);
    // cin.tie(nullptr);
    int T = read();
    // cin >> T;
    while (T--)
        solve();
    return 0;
}

这程序好像有点Bug,我给组数据试试?

详细

Test #1:

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

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

result:

ok ok 4 cases (4 test cases)

Test #2:

score: 0
Accepted
time: 18ms
memory: 5888kb

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
32 2
7
40 36 28 22 14 4 3
3
64 46 22
8
63 54 36 30 24 20 7 1
3
30 14 3
6
47 41 30 11 7 1
4
47 34 27 14
2
65 42
1
27
1
9
1
62
5
60 47 42 33 24
2
31 3
3
29 19 11
3
33 15 2
3
42 30 25
3
59 17 2
4
32 21 11 1
2
65 53
3
65 58 49
3
78 60 43
1
78
4
21 15 11 1
5
48 36 17 7 3
2
44 1
2
25 7
1
4
4
32 29 18 9
...

result:

ok ok 11000 cases (11000 test cases)

Test #3:

score: 0
Accepted
time: 30ms
memory: 6476kb

input:

2
62980 100000 9859 200000
132897 135912 27509 54599 183887 53114 127233 138596 120860 52471 83158 110644 114040 34102 100501 94779 188044 118947 57443 93009 179886 117863 142316 103026 133746 181956 88732 133751 178946 135462 99588 142382 116231 142902 98641 93039 34860 180746 34292 64655 31584 265...

output:

10
178309 138336 127053 112655 101654 91309 80278 55916 45553 25298
10
925304609 771756205 620489184 535769141 454856685 362424389 296180043 141717798 88441083 19003028

result:

ok ok 2 cases (2 test cases)

Test #4:

score: 0
Accepted
time: 38ms
memory: 6436kb

input:

2
62968 100000 987 200000
132608 47259 159851 136656 33393 145766 92631 125475 63424 186957 111759 164400 22296 95239 28164 39213 176169 72721 179002 29390 26931 55261 57111 143625 62022 48092 13696 31056 31569 136324 120007 167521 106377 119894 48641 106130 151757 146461 151941 92629 57328 134514 1...

output:

100
196025 194544 193225 191729 190380 186882 185729 180466 178269 177072 175653 174315 166890 163467 161777 159233 155137 153944 151851 150817 149284 148029 145711 143249 141795 140171 138916 136944 135917 133830 132605 131242 130085 127151 125436 124410 121321 119776 115021 112980 111180 110164 10...

result:

ok ok 2 cases (2 test cases)

Test #5:

score: 0
Accepted
time: 32ms
memory: 6620kb

input:

2
11000 100000 11 200000
163012 113063 193436 164804 38223 97954 77455 12645 65893 7472 154060 115066 197136 68157 57696 125883 36460 36327 2594 182329 52863 9384 142218 108307 164812 102263 68023 123052 114544 38027 42624 82629 131406 110330 63104 198666 154174 168712 164172 28565 120683 174248 170...

output:

1000
199938 199707 199081 198662 198625 198536 198295 198140 197279 197209 197126 197050 196941 196846 196688 196381 196180 196096 196045 196028 195728 195710 195635 195591 195515 195433 195391 195375 194694 194622 194157 194121 194106 194036 193839 193485 193427 193325 193081 192962 192817 192716 1...

result:

ok ok 2 cases (2 test cases)

Test #6:

score: 0
Accepted
time: 43ms
memory: 6444kb

input:

2
60562 100000 9 200000
124614 82957 175069 159802 77713 148208 87119 195619 137203 187199 151696 49407 92632 129159 22947 9508 83213 155794 8801 14455 4343 187591 112872 118191 84055 164173 127507 13848 193356 103420 67764 102061 151883 129600 112204 64020 118263 44490 15496 61703 177926 140419 918...

output:

9999
199990 199976 199957 199934 199925 199909 199885 199834 199822 199798 199737 199721 199710 199687 199675 199651 199637 199614 199571 199562 199540 199520 199489 199447 199427 199404 199394 199372 199349 199321 199297 199286 199277 199241 199201 199151 199088 199054 199037 199021 199011 198972 1...

result:

ok ok 2 cases (2 test cases)

Test #7:

score: 0
Accepted
time: 58ms
memory: 6784kb

input:

2
78636 100000 2 1000000
160618 689882 425029 248098 24811 473647 831221 372052 602440 158077 883901 645470 489547 863556 32157 371442 621866 941885 650516 873053 188342 224449 770318 464999 453057 304754 700410 82432 583687 478953 393561 989660 199977 458427 411530 814363 964896 69063 874312 224036...

output:

62519
999967 999965 999951 999926 999923 999916 999838 999816 999807 999801 999788 999786 999775 999767 999762 999756 999753 999746 999727 999719 999684 999657 999648 999641 999638 999600 999560 999551 999541 999524 999483 999463 999461 999449 999446 999439 999425 999423 999417 999406 999373 999362 ...

result:

ok ok 2 cases (2 test cases)

Extra Test:

score: 0
Extra Test Passed