Submission #1037737

#TimeUsernameProblemLanguageResultExecution timeMemory
1037737antonTowns (IOI15_towns)C++17
25 / 100
20 ms1116 KiB
#include "towns.h" #include<bits/stdc++.h> using namespace std; #define pii pair<int, int> const int MAX_N= 110; struct Edge{ int origin, dest; int l; Edge(){}; Edge(int _or, int _de, int _l){ l = _l; origin = _or; dest = _de; } }; int distances[MAX_N][MAX_N]; bool queried[MAX_N][MAX_N]; int getDist(int a, int b){ if(a == b){ return 0; } if(!queried[a][b]){ distances[a][b] = getDistance(a, b); distances[b][a] = distances[a][b]; queried[a][b] = true; queried[b][a] = true; } return distances[a][b]; } int n; set<int> get_pos(int a, int b){ set<int> cats; for(int i = 0; i<n; i++){ cats.insert(((getDist(a, i)-getDist(b, i))+getDist(a, b))/2); } return cats; } int find_pos(pair<int, int> axis, int i){ int a = axis.first, b= axis.second; return ((getDist(a, i)-getDist(b, i))+getDist(a, b))/2; } struct Base{ pii axis; int rootPos; Base(pii a, int rp){ axis = a; rootPos = rp; } }; bool belongs(Base b, int i){ return find_pos(b.axis, i)> b.rootPos; } int find_sz_big(pair<int, int> axis, int root_pos){ vector<pair<Base, vector<int>>> groups; groups.push_back({Base(axis, root_pos), {}}); groups.push_back({Base({axis.second, axis.first}, getDist(axis.first, axis.second)-root_pos), {}}); for(int i = 0; i<n; i++){ bool found= false; for(pair<Base, vector<int>>& g: groups){ if(belongs(g.first, i)){ g.second.push_back(i); found = true; break; } } if(!found){ groups.push_back({Base({axis.first, i}, root_pos), {i}}); } } int maxSZ = 0; for(auto e: groups){ maxSZ = max(maxSZ, (int)e.second.size()); } return maxSZ; } int R = 0; int max_dist = 0; pair<int, int> find_axis(){ int rec = 0; int next = 1; int cur = 0; for(int i = 0; i<n; i++){ if(getDist(cur, i)>rec){ rec = getDist(cur, i); next= i; } } rec= 0; cur= next; for(int i = 0; i<n; i++){ if(getDist(cur, i)>rec){ rec = getDist(cur, i); next= i; } } return {cur, next}; } pair<int, int> axis; void find_center(){ axis= find_axis(); int i = axis.first, j = axis.second; int dist_total = getDist(i, j); auto v = get_pos(i, j); int pathR = 1e9; for(auto mid: v){ pathR = min(pathR, max(mid,dist_total-mid)); } R = pathR; max_dist = dist_total; axis = {i, j}; } int hubDistance(int N, int sub) { fill(&queried[0][0], &queried[MAX_N-1][MAX_N], false); n= N; find_center(); /*int min_big_child = 1e9; for(auto e : get_pos(axis.first, axis.second)){ int dist_total = getDist(axis.first, axis.second); if(max(e, dist_total-e) == R){ min_big_child= min(min_big_child, find_sz_big(axis, e)); } } if(min_big_child <= (N/2)){ return R; } else{ return -R; }*/ return R; }

Compilation message (stderr)

towns.cpp: In function 'int hubDistance(int, int)':
towns.cpp:138:28: warning: unused parameter 'sub' [-Wunused-parameter]
  138 | int hubDistance(int N, int sub) {
      |                        ~~~~^~~
#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...