Submission #707580

#TimeUsernameProblemLanguageResultExecution timeMemory
707580nguyentunglamBridges (APIO19_bridges)C++17
30 / 100
3066 ms9084 KiB
#include<bits/stdc++.h>
#define fi first
#define se second
#define endl "\n"
#define ii pair<int, int>
using namespace std;
const int N = 1e5 + 10;
vector<ii> w[N];
int u[N], v[N];
bool mark[N];
int lab[N], n, m, ans[N];
stack<pair<int, int> > st;
int root(int v) {
    return lab[v] < 0 ? v : root(lab[v]);
}
void join(int u, int v) {
   u = root(u); v = root(v);
   if (u == v) return;
   if (lab[u] > lab[v]) swap(u, v);
   st.push({u, lab[u]});
   st.push({v, lab[v]});
   lab[u] += lab[v];
   lab[v] = u;
}
void rollback(int cnt) {
    while (st.size() > cnt) {
        lab[st.top().fi] = st.top().se;
        st.pop();
    }
}
int getw (int j, int t) {
    int idx = lower_bound(w[j].begin(), w[j].end(), make_pair(t + 1, 0)) - w[j].begin();
    return w[j][idx - 1].se;
}
vector<tuple<int, int, int> > query;
void solve() {
    sort(query.begin(), query.end(), greater<tuple<int, int, int>>());
    vector<int> remain, change;
    for(int j = 1; j <= m; j++) {
        if (!mark[j]) remain.push_back(j);
        else change.push_back(j);
        mark[j] = 0;
    }
    sort(remain.begin(), remain.end(), [] (int x, int y) {
         return w[x].back().se < w[y].back().se;
         });
    for(auto &t : query) {
        int weight, ver, idx;
        tie(weight, ver, idx) = t;
        while (!remain.empty() && w[remain.back()].back().se >= weight) {
            int j = remain.back();
            join(u[j], v[j]);
            remain.pop_back();
        }
        int pre = st.size();
        for(int &j : change) if (getw(j, idx) >= weight) {
            join(u[j], v[j]);
        }
        ans[idx] = -lab[root(ver)];
        rollback(pre);
    }
    fill(lab + 1, lab + n + 1, -1);
    while (!st.empty()) st.pop();
}
int main() {
    #define task ""
    cin.tie(0) -> sync_with_stdio(0);
    if (fopen ("task.inp", "r")) {
        freopen ("task.inp", "r", stdin);
        freopen ("task.out", "w", stdout);
    }
    if (fopen (task".inp", "r")) {
        freopen (task".inp", "r", stdin);
        freopen (task".out", "w", stdout);
    }
    cin >> n >> m;
    fill(lab + 1, lab + n + 1, -1);
    for(int i = 1; i <= m; i++) {
        int d;
        cin >> u[i] >> v[i] >> d;
        w[i].emplace_back(0, d);
    }
    int q; cin >> q;
    int T = sqrt(q);
    for(int i = 1; i <= q; i++) {
        int type, x, y; cin >> type >> x >> y;
        if (type == 1) {
            w[x].emplace_back(i, y);
            mark[x] = 1;
        }
        else query.push_back({y, x, i});
        if (i % T == 0 || i == q) solve(), query.clear();
    }
    for(int i = 1; i <= q; i++) if (ans[i]) cout << ans[i] << endl;
}

Compilation message (stderr)

bridges.cpp: In function 'void rollback(int)':
bridges.cpp:26:22: warning: comparison of integer expressions of different signedness: 'std::stack<std::pair<int, int> >::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   26 |     while (st.size() > cnt) {
      |            ~~~~~~~~~~^~~~~
bridges.cpp: In function 'int main()':
bridges.cpp:69:17: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   69 |         freopen ("task.inp", "r", stdin);
      |         ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:70:17: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   70 |         freopen ("task.out", "w", stdout);
      |         ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:73:17: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   73 |         freopen (task".inp", "r", stdin);
      |         ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:74:17: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   74 |         freopen (task".out", "w", stdout);
      |         ~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...