Submission #347746

# Submission time Handle Problem Language Result Execution time Memory
347746 2021-01-13T10:58:17 Z Harry464 Pictionary (COCI18_pictionary) C++14
14 / 140
1500 ms 7560 KB
#include <iostream>
#include <vector>
#include <set>
#include <cmath>
#include <algorithm>
#include <queue>
#include <map>

using namespace std;

typedef long long ll;

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    ll n, m, q;
    cin >> n >> m >> q;
    vector <pair <ll, ll>> kv(q);
    for (int i = 0; i < q; i++)
        cin >> kv[i].first >> kv[i].second;
    vector <ll> lo(q, 1);
    vector <ll> hi(q, m + 1);
    vector <ll> rjesenja(q, -1);
    ll rjeseni = 0;
    while (rjeseni < q){
        vector <pair <ll,ll>> mids(q);
        for (int i = 0; i < q; i++)
            mids[i].first = (lo[i]+hi[i])/2, mids[i].second = i;
        sort(mids.begin(), mids.end());
        vector <ll> par(n+1);
        vector <ll> ranks(n+1,0);
        for (int i = 0; i < n; i++)
            par[i+1] = i + 1;
        ll slid = 0;
        for (int i = 0; i < m; i++){
            ll tren = 2*(m - i);
            while (tren <= n){
                ll part = tren;
                while (part != par[part])
                    part = par[part];
                ll pars = m - i;
                while (pars != par[pars])
                    pars = par[pars];
                if (pars == part){
                    tren += m - i;
                    continue;
                }
                if (ranks[pars] < ranks[part])
                    swap(pars,part);
                par[part] = pars;
                if (ranks[pars] == ranks[part]) ranks[pars]++;
                tren += m - i;
            }
            while (slid <= n && mids[slid].first == i + 1){
                ll upit = mids[slid].second;
                if (rjesenja[upit] != -1){
                    slid++;
                    continue;
                }
                ll para = kv[upit].first, parb = kv[upit].second;
                while (para != par[para])
                    para = par[para];
                while (parb != par[parb])
                    parb = par[parb];
                if (para == parb){
                    hi[upit] = i + 1;
                } else {
                   lo[upit] = i + 2;
                }
                if (lo[upit] >= hi[upit])
                    rjeseni++, rjesenja[upit] = lo[upit];
                slid++;
            }
        }
    }
    for (int i = 0; i < q; i++)
        cout << rjesenja[i] << endl;
}
# Verdict Execution time Memory Grader output
1 Execution timed out 1588 ms 620 KB Time limit exceeded
# Verdict Execution time Memory Grader output
1 Execution timed out 1547 ms 1388 KB Time limit exceeded
# Verdict Execution time Memory Grader output
1 Execution timed out 1562 ms 4076 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1583 ms 5868 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1568 ms 3180 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1587 ms 3468 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1600 ms 4748 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1549 ms 5996 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1576 ms 6460 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 783 ms 7512 KB Output is correct
2 Correct 779 ms 7560 KB Output is correct