Submission #347728

# Submission time Handle Problem Language Result Execution time Memory
347728 2021-01-13T10:46:13 Z Harry464 Pictionary (COCI18_pictionary) C++14
0 / 140
1500 ms 6668 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);
        for (int i = 0; i < n; i++)
            par[i] = i;
        ll slid = 0;
        for (int i = 0; i < m; i++){
            ll tren = 2*(m - i);
            while (tren <= n){
                ll part = tren-1;
                while (part != par[part])
                    part = par[part];
                par[part] = m - i - 1;
                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-1, parb = kv[upit].second-1;
                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 1576 ms 620 KB Time limit exceeded
# Verdict Execution time Memory Grader output
1 Execution timed out 1570 ms 1388 KB Time limit exceeded
# Verdict Execution time Memory Grader output
1 Execution timed out 1582 ms 4076 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1593 ms 5868 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1580 ms 2948 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1581 ms 3276 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1569 ms 4464 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1569 ms 5572 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1584 ms 5884 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Execution timed out 1573 ms 6668 KB Time limit exceeded
2 Halted 0 ms 0 KB -