Submission #380394

#TimeUsernameProblemLanguageResultExecution timeMemory
380394CaroLindaSaveit (IOI10_saveit)C++14
100 / 100
1397 ms19884 KiB
#include "grader.h" #include "encoder.h" #include <bits/stdc++.h> #define debug printf #define lp(i,a,b) for(int i = a; i < b ; i++ ) #define ll long long #define all(x) x.begin(),x.end() #define sz(x) (int)(x.size() ) #define pb push_back #define mk make_pair #define ff first #define ss second #define pii pair<int,int> const int MAXN = 1010 ; const int BASE = 2 ; using namespace std ; struct bignum { vector<int> a ; void trim() { while( sz(a) > 0 && a.back() == 0 ) a.pop_back() ; } bignum operator + (bignum other) const { bignum aux ; for(int i = 0 , carry = 0 ; i < max(sz(other.a), sz(a)) || carry ; i++ ) { int addOther = (i >= sz(other.a) ) ? 0 : other.a[i] ; int addThis = (i >= sz(a) ) ? 0 : a[i] ; aux.a.push_back( addOther + addThis + carry ) ; carry = ( aux.a.back() >= BASE ) ; if(carry) aux.a.back() -= BASE ; } return aux ; } bool operator < ( bignum other ) const { if( sz(a) != sz(other.a) ) return sz(a) < sz(other.a) ; for(int i = sz(a) - 1 ; i >= 0 ; i-- ) if( a[i] != other.a[i] ) return a[i] < other.a[i] ; return false ; } bool operator == (bignum other) const { return !(*this < other) && !(other < *this) ; } bool operator <= (bignum other) { return !(other < *this ) ; } bignum operator - (bignum other )const { bignum aux ; for(int i = 0 ,carry=0 ; i < max(sz(a), sz(other.a) ) ; i++ ) { int myNumber = ( i >= sz(a) ) ? 0 : a[i] ; int otherNumber = ( i >= sz(other.a) ) ? 0 : other.a[i] ; aux.a.push_back( myNumber - otherNumber - carry ) ; carry = ( aux.a.back() < 0 ) ; if(carry ) aux.a.back() += BASE ; } aux.trim() ; return aux ; } } ; static bignum pot[1000] ; static int N , H ; static int dist[MAXN] , par[MAXN] ; static vector<int> adj[MAXN] ; static vector<int> tree[MAXN] ; static bool vis[MAXN] ; bool isOn(int i , int mask ) { return ((1<<i)&mask) != 0 ; } void dfs(int x) { vis[x] = true ; for(auto e : adj[x] ) { if( vis[e] ) continue ; tree[x].pb(e) ; tree[e].pb(x) ; par[e] = x ; dfs(e) ; } } void runBfs(int sc) { vector<int> fila(1,sc) ; for(int i = 0 ; i < N ; i++ ) dist[i] = N+10 ; dist[sc] = 0 ; int ptr = 0 ; while(ptr < sz(fila) ) { int x = fila[ptr++] ; for(auto e : adj[x] ) { if( dist[e] <= dist[x] + 1 ) continue ; dist[e] = dist[x]+1 ; fila.pb(e) ; } } } void encode(int nv, int nh, int ne, int *v1, int *v2) { N = nv ; H = nh ; for(int i = 0 ; i < ne ; i++ ) { adj[ v1[i] ].pb( v2[i] ) ; adj[ v2[i] ].pb( v1[i] ) ; } dfs(0) ; set<int> fila ; vector<int> deg(nv+10) ; for(int i = 0 ; i < nv ; i++ ) { deg[i] = sz(tree[i] ) ; if( deg[i] == 1 ) fila.insert(i) ; } int cnt = nv-2 ; while( cnt-- ) { int x = *fila.begin() ; deg[x] = 0 ; fila.erase( fila.begin() ) ; for(auto e : tree[x] ) if( deg[e] ) { x = e ; break ; } if( (--deg[x] ) == 1 ) fila.insert(x) ; for(int i = 9 ; i >= 0 ; i-- ) encode_bit( isOn(i, x) ) ; } /* lp(i,0,nv) for(auto e : tree[i] ) { if( i > e ) continue ; for(int j = 9 ;j >= 0 ; j-- ) encode_bit( isOn(j,i) ) ; for(int j = 9 ; j >= 0 ; j-- ) encode_bit( isOn(j,e) ) ; } */ // freopen("out_encode.txt", "w", stdout ) ; /*debug("Arvore que recebi\n" ) ; for(int i = 0 ; i < nv ; i++ ) for(auto e : tree[i] ) if( i < e ) debug("%d %d\n", i, e ) ; */ pot[0].a.pb(1) ; for(int i = 1 ; i <= 998 ; i++ ) { pot[i] = pot[i-1] + pot[i-1] ; pot[i] = pot[i] + pot[i-1] ; } bignum big ; for(int i = 0 ; i < nh ; i++ ) { runBfs(i) ; if( i != 0 ) for(int j = 9 ; j >= 0 ; j-- ) encode_bit( isOn(j,dist[0] ) ) ; big.a.clear() ; big.a.pb(0) ; for(int j = 1 , cnt = -1 ; j < nv ; j++ ) { if( j == i ) continue ; cnt++ ; if( dist[j] == dist[ par[j] ]-1 ) continue ; big = big + pot[cnt] ; if( dist[j] == dist[ par[j] ]+1 ) big = big + pot[cnt] ; } /*for(auto e : big.a ) cout << e <<" " ; cout << endl ; */ for(int j = 0 ; j < 1590 ; j++ ) { if( j >= sz(big.a) ) encode_bit(0) ; else encode_bit( big.a[j] ) ; } } }
#include "grader.h" #include "decoder.h" #include <bits/stdc++.h> #define debug printf #define lp(i,a,b) for(int i = a; i < b ; i++ ) #define ll long long #define all(x) x.begin(),x.end() #define sz(x) (int)(x.size() ) #define pb push_back #define mk make_pair #define ff first #define ss second #define pii pair<int,int> const int MAXN = 1010 ; const int BASE = 2 ; using namespace std ; struct bignum { vector<int> a ; void trim() { while( sz(a) > 0 && a.back() == 0 ) a.pop_back() ; } bignum operator + (bignum other) const { bignum aux ; for(int i = 0 , carry = 0 ; i < max(sz(other.a), sz(a)) || carry ; i++ ) { int addOther = (i >= sz(other.a) ) ? 0 : other.a[i] ; int addThis = (i >= sz(a) ) ? 0 : a[i] ; aux.a.push_back( addOther + addThis + carry ) ; carry = ( aux.a.back() >= BASE ) ; if(carry) aux.a.back() -= BASE ; } return aux ; } bool operator < ( bignum other ) const { if( sz(a) != sz(other.a) ) return sz(a) < sz(other.a) ; for(int i = sz(a) - 1 ; i >= 0 ; i-- ) if( a[i] != other.a[i] ) return a[i] < other.a[i] ; return false ; } bool operator == (bignum other) const { return !(*this < other) && !(other < *this) ; } bool operator <= (bignum other) { return !(other < *this ) ; } bignum operator - (bignum other )const { bignum aux ; for(int i = 0 ,carry=0 ; i < max(sz(a), sz(other.a) ) ; i++ ) { int myNumber = ( i >= sz(a) ) ? 0 : a[i] ; int otherNumber = ( i >= sz(other.a) ) ? 0 : other.a[i] ; aux.a.push_back( myNumber - otherNumber - carry ) ; carry = ( aux.a.back() < 0 ) ; if(carry ) aux.a.back() += BASE ; } aux.trim() ; return aux ; } } ; static bignum pot[1000] ; static vector<int> tree[MAXN] ; static int dist[MAXN] , par[MAXN] ; static bool vis[MAXN] ; int id[MAXN] , v[MAXN] ; void dfs2(int x) { vis[x] = true ; for(auto e : tree[x] ) { if( vis[e] ) continue ; par[e] = x ; dfs2(e) ; } } void dfs3(int x) { if( x && id[x] != -1 ) { if( v[ id[x] ] == 0 ) dist[x] = dist[ par[x] ]-1 ; else if( v[ id[x] ] == 1 ) dist[x] = dist[ par[x] ] ; else dist[x] = dist[ par[x] ] + 1 ; } for(auto e : tree[x] ) { if( e == par[x] ) continue ; dfs3(e) ; } } void decode(int nv, int nh) { vector<int> prufer( nv-2, 0) ; for(int i = 0 ; i < nv-2 ; i++ ) for(int j = 9 ; j >= 0 ; j-- ) if( decode_bit() ) prufer[i] += (1<<j) ; vector<int> deg(nv, 1) ; for(auto e : prufer ) deg[e]++ ; set<int> s ; for(int i = 0 ; i < nv ; i++ ) if( deg[i] == 1 ) s.insert(i) ; for(auto e : prufer ) { int x = *s.begin() ; s.erase( s.begin() ) ; tree[x].pb(e) ; tree[e].pb(x) ; if( (--deg[e]) == 1 ) s.insert(e) ; } tree[ *s.begin() ].pb( nv-1 ) ; tree[ nv-1 ].pb( *s.begin() ) ; /* for(int i = 0 ; i < nv-1; i++ ) { int a = 0 , b = 0 ; for(int j = 9 ; j >= 0 ; j-- ) if( decode_bit() ) a += (1<<j) ; for(int j = 9 ; j >= 0 ; j-- ) if( decode_bit() ) b += (1<<j) ; tree[a].pb(b) ; tree[b].pb(a) ; } */ //freopen("out_decode.txt", "w", stdout) ; /* debug("Arvore que recebi\n") ; for(int i = 0 ; i < nv ; i++ ) for(auto e : tree[i] ) if( i < e ) debug("%d %d\n", i, e ) ; */ dfs2(0) ; pot[0].a.pb(1) ; for(int i = 1 ; i <= 998 ; i++ ) { pot[i] = pot[i-1] + pot[i-1] ; pot[i] = pot[i] + pot[i-1] ; } bignum big ; for(int i = 0 ; i < nh ; i++ ) { big.a.clear() ; dist[0] = dist[i] = 0 ; if(i != 0 ) for(int j = 9 ; j >= 0 ; j-- ) if( decode_bit() ) dist[0] += (1<<j) ; for(int i = 0 ; i < 1590 ; i++ ) big.a.pb( decode_bit() ) ; big.trim() ; for(int j = nv-2 ; j >= 0 ; j-- ) { v[j] = 0 ; while( pot[j] <= big ) { v[j]++ ; big = big - pot[j] ; } } for(int j = 1 , cnt = 0 ; j < nv ; j++) { if(j == i ) { id[j] = -1 ; continue ; } id[j] = cnt ; cnt++ ; } dfs3(0) ; for(int j = 0 ; j < nv ; j++ ) hops(i, j, dist[j] ) ; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...