QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#118050#6680. HeapUndertrainedOverpressure#WA 117ms4172kbC++231.7kb2023-07-02 23:26:012023-07-02 23:26:04

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-07-02 23:26:04]
  • 评测
  • 测评结果:WA
  • 用时:117ms
  • 内存:4172kb
  • [2023-07-02 23:26:01]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef long double ld;
#define TIME (clock() * 1.0 / CLOCKS_PER_SEC)

void solve() {
    int n;
    cin >> n;
    vector<int> v(n + 1);
    for (int i = 1; i <= n; i++) {
        cin >> v[i];
    }
    vector<int> a(n + 1);
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
    }
    string ans;
    for (int i = n; i >= 1; i--) {
        int p = i;
        vector<int> idx;
        while (p > 0) {
            idx.emplace_back(p);
            if (a[p] == v[i]) {
                break;
            }
            p /= 2;
        }
        if (p == 0) {
            cout << "Impossible\n";
            return;
        }
        if (p == i) {
            ans += '0';
            continue;
        }
        int mn = 1;
        int mx = -1;
        for (int j = (int)idx.size() - 1; j > 0; j--) {
            int x = idx[j];
            int y = idx[j - 1];
            //cerr << x << " " << y << "\n";
            if (a[x] > a[y]) {
                mn = min(mn, -1);
                mx = max(mx, -1);
            } else {
                mn = min(mn, 1);
                mx = max(mx, 1);
            }
            swap(a[x], a[y]);
        }
        if (mn != mx) {
            cout << "Impossible\n";
            return;
        }
        if (mn == -1) {
            ans += '1';
        } else {
            ans += '0';
        }
    }
    reverse(ans.begin(), ans.end());
    cout << ans << "\n";
}

int main() {
#ifdef ONPC
    freopen("input", "r", stdin);
#endif
    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: 3392kb

input:

3
4
2 3 1 4
4 1 3 2
5
4 5 1 2 3
3 4 1 5 2
3
1 1 2
2 1 1

output:

0101
Impossible
001

result:

ok 3 lines

Test #2:

score: -100
Wrong Answer
time: 117ms
memory: 4172kb

input:

1118
77
210555 375330 669075 785279 194474 310626 830710 886719 102133 426324 41900 971872 167203 702222 230534 112350 673156 358623 886831 72864 818751 367894 842740 531878 818794 131219 412128 104469 70427 658494 72060 768735 915294 161365 91671 451974 121863 498890 408674 670274 875754 967228 518...

output:

00010011010000000000101000100001100000010000100100001000001000001000101000000
000001000010010
01011010110010010000000100001100100000000000011000000100
0
Impossible
00
010001000000000000110010000000010010101010101000000000001100000010
Impossible
Impossible
010001011
0010000001001000000000110000100100...

result:

wrong answer 1st lines differ - expected: '000101111110101000001010001010...0101001001001000001100111100010', found: '000100110100000000001010001000...0100001000001000001000101000000'