QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#501097#2264. Secrets of Legendary Treasureyzkkai#TL 0ms3612kbC++201.4kb2024-08-02 14:07:452024-08-02 14:07:47

Judging History

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

  • [2024-08-02 14:07:47]
  • 评测
  • 测评结果:TL
  • 用时:0ms
  • 内存:3612kb
  • [2024-08-02 14:07:45]
  • 提交

answer

#include <bits/stdc++.h>
#define sz(x) signed(size(x))
using namespace std;
using ll = long long;
using LL = long long;

inline void solve() {
    int n, m;
    cin >> n >> m;

    vector<int> a(n), b(m), in(n + m + 1);
    for (int& i : a) {
        cin >> i;
        in[i] = 1;
    }
    for (int& i : b) {
        cin >> i;
        in[i] = 1;
    }

    auto dfs = [&](auto& self, int i, int j, int cnt) -> bool {
        if (i == n && j == m)
            return 1;

        if (i && a[i] != 0 && a[i] < a[i - 1]) return 0;
        if (j && b[j] != 0 && b[j] < b[j - 1]) return 0;

        while (in[cnt]) ++cnt;
        if (i < n && a[i] == 0) {
            a[i] = cnt;
            if (self(self, i + 1, j, cnt + 1))
                return 1;
            a[i] = 0;
        }
        if (j < m && b[j] == 0) {
            b[j] = cnt;
            if(self(self, i, j + 1, cnt + 1))
                return 1;
            b[j] = 0;
        }

        if ((i < n && a[i] == 0) || (i < m && b[j] == 0)) return 0;
        return self(self, i + (i < n), j + (j < m), cnt);
    };

    dfs(dfs, 0, 0, 1);
    for (int i : a)
        cout << i << ' ';
    cout << '\n';
    for (int i : b)
        cout << i << ' ';
    cout << '\n';
}

signed main() {
    cin.tie(0)->sync_with_stdio(0);
    int t = 1;
    while (t--)
        solve();
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3484kb

input:

100 100
1 2 3 4 6 10 11 14 17 18 19 21 24 25 26 27 29 32 34 35 36 37 39 40 44 49 52 53 55 59 65 66 67 68 73 74 81 82 83 85 86 88 89 90 96 98 99 102 103 104 106 107 108 116 117 118 121 124 127 128 129 130 131 132 134 137 138 139 141 145 148 149 152 153 154 156 157 158 161 162 163 167 169 170 173 174 ...

output:

1 2 3 4 6 10 11 14 17 18 19 21 24 25 26 27 29 32 34 35 36 37 39 40 44 49 52 53 55 59 65 66 67 68 73 74 81 82 83 85 86 88 89 90 96 98 99 102 103 104 106 107 108 116 117 118 121 124 127 128 129 130 131 132 134 137 138 139 141 145 148 149 152 153 154 156 157 158 161 162 163 167 169 170 173 174 175 177 ...

result:

ok correct

Test #2:

score: 0
Accepted
time: 0ms
memory: 3612kb

input:

99 1
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
37

output:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 
37 

result:

ok correct

Test #3:

score: -100
Time Limit Exceeded

input:

90 96
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 92
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...

output:


result: