Submission #958304

#TimeUsernameProblemLanguageResultExecution timeMemory
958304thunoproSwapping Cities (APIO20_swap)C++14
37 / 100
2068 ms13140 KiB
#include<bits/stdc++.h> using namespace std ; #define maxn 250009 #define ll long long #define pb push_back #define fi first #define se second #define left id<<1 #define right id<<1|1 #define re exit(0); #define _lower(x) lower_bound(v.begin(),v.end(),x)-v.begin()+1 #define TIME (1.0*clock()/CLOCK_PERS_SEC) const int mod = 1e9+7 ; const int INF = 1e9 ; typedef vector<int> vi ; typedef pair<int,int> pii ; typedef vector<pii> vii ; void add ( int &a , int b ) { a += b ; if ( a >= mod ) a -= mod ; if ( a < 0 ) a += mod ; } template < typename T > void chkmin ( T &a , T b ) { if ( a > b ) a = b ;} template < typename T > void chkmax ( T &a , T b ) { if ( a < b ) a = b ;} void rf () { freopen("bai1.inp","r",stdin) ; } int _pow ( int a , int n ) { if ( n == 0 ) return 1 ; int res = _pow (a,n/2) ; if ( n % 2 ) return 1ll*res*res%mod*a%mod ; else return 1ll*res*res%mod ; } mt19937 rng(time(0)) ; //#include "grader.h" int n , m ; vi u , v , w ; int lab [maxn] , deg [maxn] ; struct shape { int u , v , w ; }e[maxn]; bool cmp ( shape u , shape v ) { return u.w < v.w ; } void init ( int N , int M , vi U , vi V , vi W ) { n = N , m = M ; for ( int i = 0 ; i < m ; i ++ ) { U [i] ++ , V [i] ++ ; e [i+1] = {U[i],V[i],W[i]} ; } sort (e+1,e+m+1,cmp) ; } int find ( int u ) { return (lab[u]<0?u:lab[u]=find(lab[u])) ; } void uni ( int u , int v ) { if ((u=find(u)) == (v=find(v))) return ; if ( lab [u] > lab [v] ) swap (u,v) ; lab [u] += lab [v] ; lab [v] = u ; } int getMinimumFuelCapacity ( int x , int y ) { x ++ , y ++ ; int l = 1 , r = m ; int res = -1 ; while ( l <= r ) { for ( int i = 1 ; i <= n ; i ++ ) lab [i] = -1 , deg [i] = 0 ; int mid = (l+r)/2 ; bool ok = false ; for ( int i = 1 ; i <= mid ; i ++ ) { if (find(e[i].u) == find(e[i].v) && find(e[i].u) == find(x) && find(e[i].u) == find(y)) ok = true ; deg [e[i].u] ++ , deg [e[i].v] ++ ; uni (e[i].u,e[i].v) ; } for ( int i = 1 ; i <= n ; i ++ ) { if ( deg [i] >= 3 && find (i) == find (x) && find (i) == find (y) ) ok = true ; } if ( ok == true ) res = e[mid].w , r = mid-1 ; else l = mid+1 ; } return res ; } //int main () //{ // init(5, 6, {0, 0, 1, 1, 1, 2}, {1, 2, 2, 3, 4, 3}, {4, 4, 1, 2, 10, 3}); // cout << getMinimumFuelCapacity(1,2) ; //}

Compilation message (stderr)

swap.cpp: In function 'void rf()':
swap.cpp:33:9: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   33 |  freopen("bai1.inp","r",stdin) ;
      |  ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~
#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...