Submission #105436

#TimeUsernameProblemLanguageResultExecution timeMemory
105436CaroLindaTowns (IOI15_towns)C++14
35 / 100
27 ms512 KiB
#include "towns.h" #include <bits/stdc++.h> #define lp(i,a,b) for(int i = a ; i < b ; i++) #define ff first #define ss second #define pb push_back #define pii pair<int,int> #define MAXN 120 const int inf = 1e9 + 5 ; using namespace std; // int N , A , B , R , man; int perp[MAXN] ; int v[] = {0,0,0} ; int d[MAXN][MAXN] ; bool marc[MAXN][MAXN] ; // //union-find stuff int pai[MAXN] , h[MAXN]; void init() { memset( v , 0 , sizeof v ) ; lp(i,0,N) pai[i] = i ; memset( h , 0 , sizeof h ) ; memset(marc , 0 , sizeof marc ) ; lp(i,0,N) marc[i][i] = 1 ; } int getDist( int x , int y ) { if( marc[x][y] ) return d[x][y] ; marc[x][y] = marc[y][x] = 1 ; d[x][y] = d[y][x] = getDistance( x , y ) ; return d[x][y] ; } void query( int x ) { lp(i,0,N) d[x][i] = getDist( x, i ) ; } int findMax( int x ) { return max_element(d[x] , d[x] + N) - d[x] ; } int findPerpendicular( int x ) { return (d[A][x] + d[B][x] - d[A][B])/2 ; } int findRadio() { int ans = inf ; lp(i,0,N) { int k = max( d[A][i] , d[B][i] ) - perp[i] ; int Man = d[A][i] > d[B][i] ? A : B ; if( k < ans ) ans = k , man = Man ; } return ans ; } int checkPosition( int x ) { int k = d[man][x] - perp[x] ; if( k < R ) return 0 ; if( k == R ) return 1 ; return 2 ; } int sub4() { lp(i,0,N) v[ checkPosition(i) ] ++ ; lp(i,0,3) if( v[i] > N/2 ) return -R ; return R ; } bool check( vector<int> &vec ) { if(vec.size() == 0) return 0 ; int bucket = 0 , now = vec[0] ; lp( i , 1 , vec.size() ) { if( getDist( now , vec[i]) == perp[now] + perp[ vec[i] ] ) { //different componentes if( !bucket ) now = vec[i] , bucket = 1; else bucket -- ; } bucket ++ ; } bucket = vec.size() ; for(auto it : vec) if( getDist(now , it) == perp[now] + perp[it] ) bucket -- ; return (bucket <= N/2) ; } int hubDistance( int n , int sub) { N = n ; init() ; query(0) ; A = findMax(0) ; query(A) ; B = findMax(A) ; query(B) ; lp(i,0,n) perp[i] = findPerpendicular(i) ; R = findRadio() ; if( sub < 3 ) return R ; if( sub == 4 ) return sub4() ; vector<int> s1 , s2 ; bool balanced = 0 ; lp(i,0,N) if( checkPosition(i) == 1 ) s1.pb(i) ; balanced |= check(s1) ; int ori = R ; R = d[A][B] - R ; lp(i,0,N) if( checkPosition(i) == 1 ) s2.pb(i) ; balanced |= check(s2) ; balanced = (balanced == 1) ? 1 : -1 ; return ori * balanced ; }

Compilation message (stderr)

towns.cpp: In function 'int findMax(int)':
towns.cpp:48:39: warning: conversion to 'int' from 'long int' may alter its value [-Wconversion]
 { return max_element(d[x] , d[x] + N) - d[x] ; }
          ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~
towns.cpp: In function 'bool check(std::vector<int>&)':
towns.cpp:4:37: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
 #define lp(i,a,b) for(int i = a ; i < b ; i++)
towns.cpp:86:7:
   lp( i , 1 , vec.size() )
       ~~~~~~~~~~~~~~~~~~             
towns.cpp:86:3: note: in expansion of macro 'lp'
   lp( i , 1 , vec.size() )
   ^~
towns.cpp:97:20: warning: conversion to 'int' from 'std::vector<int>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
   bucket = vec.size() ;
            ~~~~~~~~^~
towns.cpp: In function 'int hubDistance(int, int)':
towns.cpp:131:28: warning: ?: using integer constants in boolean context, the expression will always evaluate to 'true' [-Wint-in-bool-context]
 balanced = (balanced == 1) ? 1 : -1 ;
            ~~~~~~~~~~~~~~~~^~~~~~~~
#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...