Submission #722694

#TimeUsernameProblemLanguageResultExecution timeMemory
722694SonBridges (APIO19_bridges)C++14
59 / 100
3049 ms10428 KiB
#include <bits/stdc++.h> using namespace std; #define LL long long #define pb push_back int n,m,q; int U[100005], V[100005], W[100005]; int T[100005], X[100005], Y[100005]; int ans[100005]; int dsu[100005], sz[100005]; const int D = 500; bool changed[100005]; vector < int > to_join[100005],stck; int rt( int a ){ if ( dsu[a] == a ) return a; return rt(dsu[a]); } bool cmp_ask( int a, int b ){ return Y[a] > Y[b]; } bool cmp_unchanged( int a, int b ){ return W[a] > W[b]; } void merge( int a, int b ){ if ( rt(a) == rt(b) ) return; if ( sz[rt(a)] > sz[rt(b)] ) swap(a,b); stck.pb(rt(a)); sz[rt(b)] += sz[rt(a)]; dsu[rt(a)] = rt(b); } void rollback( int prev_stack_size ){ while ( stck.size() > prev_stack_size ) { int a = stck.back(); stck.pop_back(); sz[rt(a)] -= sz[a]; dsu[a] = a; } } int main(){ scanf("%d%d",&n,&m); for ( int i = 1; i <= m; i++ ){ scanf("%d%d%d",&U[i],&V[i],&W[i]); } scanf("%d",&q); for ( int i = 1; i <= q; i++ ){ scanf("%d%d%d",&T[i],&X[i],&Y[i]); } for ( int l = 1; l <= q; l += D){ int r = min(q + 1, l + D ); memset(changed,false,sizeof(changed)); vector < int > upd,ask,unchanged; stck.clear(); for ( int i = l; i < r; i++ ){ if ( T[i] == 1 ) { changed[X[i]] = true; upd.pb(i); } else { ask.pb(i); } } for ( int i = l; i < r; i++ ){ if ( T[i] == 1 ){ W[X[i]] = Y[i]; continue; } to_join[i-l].clear(); if ( T[i] == 2 ){ for ( int j : upd ){ if ( W[X[j]] >= Y[i] ) to_join[i-l].pb(j); } } } for ( int i = 1; i <= m; i++ ){ if ( !changed[i] ){ unchanged.pb(i); } } sort(unchanged.begin(),unchanged.end(),cmp_unchanged); sort(ask.begin(),ask.end(),cmp_ask); for ( int i = 1; i <= n; i++ ){ dsu[i] = i; sz[i] = 1; } int ptr = 0; for ( int i : ask ){ while ( ptr < unchanged.size() && W[unchanged[ptr]] >= Y[i] ){ merge(U[unchanged[ptr]], V[unchanged[ptr]]); ptr++; } int stack_size = (int)stck.size(); for ( int j : to_join[i-l] ) merge(U[X[j]], V[X[j]]); ans[i] = sz[rt(X[i])]; rollback(stack_size); } } for ( int i = 1; i <= q; i++ ) if ( T[i] == 2 ) printf("%d\n",ans[i]); return 0; }

Compilation message (stderr)

bridges.cpp: In function 'void rollback(int)':
bridges.cpp:38:25: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   38 |     while ( stck.size() > prev_stack_size ) {
      |             ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~
bridges.cpp: In function 'int main()':
bridges.cpp:100:25: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  100 |             while ( ptr < unchanged.size() && W[unchanged[ptr]] >= Y[i] ){
      |                     ~~~~^~~~~~~~~~~~~~~~~~
bridges.cpp:48:10: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   48 |     scanf("%d%d",&n,&m);
      |     ~~~~~^~~~~~~~~~~~~~
bridges.cpp:50:14: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   50 |         scanf("%d%d%d",&U[i],&V[i],&W[i]);
      |         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
bridges.cpp:52:10: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   52 |     scanf("%d",&q);
      |     ~~~~~^~~~~~~~~
bridges.cpp:54:14: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   54 |         scanf("%d%d%d",&T[i],&X[i],&Y[i]);
      |         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
#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...