답안 #605021

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
605021 2022-07-25T12:20:09 Z SlavicG CEOI16_icc (CEOI16_icc) C++17
90 / 100
175 ms 616 KB
#include "icc.h"
#include <bits/stdc++.h>
using namespace std;

/*
int query(int a, int b, int* aa, int* bb) {

}
*/

mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());

int query(vector<int> a, vector<int> b) {
    int aa[(int)a.size()], bb[(int)b.size()];
    for(int i = 0; i < (int)a.size(); ++i) aa[i] = a[i];
    for(int i = 0; i < (int)b.size(); ++i) bb[i] = b[i];
    return query(a.size(), b.size(), aa, bb);
}
struct dsu {
    vector<int> p;
    dsu(int n) {
        p.resize(n);
        iota(p.begin(), p.end(), 0);
    }
    int get(int a) {return p[a] = (p[a] == a ? a : get(p[a]));}
    void uni(int a, int b) {
        a = get(a);
        b = get(b);
        if(a < b) swap(a, b);
        p[a] = b;
    }
};

void run(int n) {
    dsu d(n + 5);
    for(int times = 0; times < n - 1; ++times) {
        int st = -1;
        vector<int> v;
        for(int i = 1; i <= n; ++i) v.push_back(d.get(i));
        sort(v.begin(), v.end());
        v.erase(unique(v.begin(), v.end()), v.end());
        vector<int> A, B;
        vector<int> bits;
        for(int bit = 0; (1 << bit) < n; ++bit) bits.push_back(bit);
        shuffle(bits.begin(), bits.end(), rng);
        int mn = INT_MAX;
        for(int bit: bits) {
            vector<int> c1, c2;
            for(int i = 1; i <= n; ++i) {
                if((d.get(i) - 1) & (1 << bit)) c1.push_back(i);
                else c2.push_back(i);
            }
            if(c1.empty() || c2.empty()) continue;
            if(query(c1, c2)) {
                if(ceil(log2(c1.size())) + ceil(log2(c2.size())) < mn) {
                    mn = ceil(log2(c1.size())) + ceil(log2(c2.size()));
                    A = c1, B = c2;
                    break;
                }
            }
        }
        assert(A.size() > 0 && B.size() > 0);
        shuffle(A.begin(), A.end(), rng);
        shuffle(B.begin(), B.end(), rng);
        int ansA = -1, ansB = -1;
        int l = 0, r = (int)A.size() - 1;
        while(l <= r) {
            int mid = l + r >> 1;
            vector<int> paiu;
            for(int i = 0; i <= mid; ++i) paiu.push_back(A[i]);
            if(query(paiu, B)) {
                ansA = A[mid];
                r = mid - 1;
            } else l = mid + 1;
        }
        l = 0, r = (int)B.size() - 1;
        while(l <= r) {
            int mid = l + r >> 1;
            vector<int> paiu;
            for(int i = 0; i <= mid; ++i) paiu.push_back(B[i]);
            if(query(paiu, A)) {
                ansB = B[mid];
                r = mid - 1;
            } else l = mid + 1;
        }
        assert(ansA != -1 && ansB != -1);
        d.uni(ansA, ansB);
        setRoad(ansA, ansB);
    }
}

/*
int main() {
    int n; cin >> n;
    run(n);
}
*/

Compilation message

icc.cpp: In function 'void run(int)':
icc.cpp:68:25: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   68 |             int mid = l + r >> 1;
      |                       ~~^~~
icc.cpp:78:25: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   78 |             int mid = l + r >> 1;
      |                       ~~^~~
icc.cpp:37:13: warning: unused variable 'st' [-Wunused-variable]
   37 |         int st = -1;
      |             ^~
# 결과 실행 시간 메모리 Grader output
1 Correct 6 ms 468 KB Ok! 109 queries used.
2 Correct 6 ms 468 KB Ok! 106 queries used.
# 결과 실행 시간 메모리 Grader output
1 Correct 34 ms 480 KB Ok! 538 queries used.
2 Correct 48 ms 484 KB Ok! 733 queries used.
3 Correct 39 ms 476 KB Ok! 694 queries used.
# 결과 실행 시간 메모리 Grader output
1 Correct 115 ms 500 KB Ok! 1446 queries used.
2 Correct 146 ms 612 KB Ok! 1772 queries used.
3 Correct 117 ms 488 KB Ok! 1478 queries used.
4 Correct 130 ms 468 KB Ok! 1560 queries used.
# 결과 실행 시간 메모리 Grader output
1 Correct 151 ms 500 KB Ok! 1540 queries used.
2 Correct 127 ms 492 KB Ok! 1554 queries used.
3 Correct 131 ms 488 KB Ok! 1634 queries used.
4 Correct 114 ms 496 KB Ok! 1461 queries used.
# 결과 실행 시간 메모리 Grader output
1 Correct 141 ms 468 KB Ok! 1643 queries used.
2 Correct 175 ms 492 KB Ok! 1656 queries used.
3 Correct 137 ms 496 KB Ok! 1715 queries used.
4 Correct 132 ms 496 KB Ok! 1628 queries used.
5 Correct 115 ms 504 KB Ok! 1497 queries used.
6 Correct 138 ms 488 KB Ok! 1627 queries used.
# 결과 실행 시간 메모리 Grader output
1 Incorrect 143 ms 616 KB Too many queries! 1655 out of 1625
2 Halted 0 ms 0 KB -