Submission #542602

#TimeUsernameProblemLanguageResultExecution timeMemory
542602tranxuanbachTowns (IOI15_towns)C++17
0 / 100
1 ms340 KiB
#ifndef FEXT #include "towns.h" #endif #include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> using namespace std; using namespace __gnu_pbds; #define endl '\n' #define fi first #define se second #define For(i, l, r) for (auto i = (l); i < (r); i++) #define ForE(i, l, r) for (auto i = (l); i <= (r); i++) #define FordE(i, l, r) for (auto i = (l); i >= (r); i--) #define Fora(v, a) for (auto v: (a)) #define bend(a) (a).begin(), (a).end() #define isz(a) ((signed)(a).size()) using ll = long long; using ld = long double; using pii = pair <int, int>; using vi = vector <int>; using vpii = vector <pii>; using vvi = vector <vi>; #ifdef FEXT struct grader_t{ static const int N = 110 + 5; int n; int dist[N][N]; } cac; int getDistance(int i, int j){ if (min(i, j) < 0 or max(i, j) >= cac.n){ return 0; } return cac.dist[i][j]; } #endif namespace { const int N = 110 + 5; int dist[N][N]; int getdist(int u, int v){ if (u > v){ swap(u, v); } if (dist[u][v] = -1){ if (u == v){ dist[u][v] = 0; } else{ dist[u][v] = getDistance(u, v); } } return dist[u][v]; } } int hubDistance(int n, int subtask){ memset(dist, -1, sizeof(dist)); // if (subtask == 1 or subtask == 2){ int dia1 = 0, dia2 = 0; For(u, 1, n){ if (getdist(0, u) > getdist(0, dia1)){ dia1 = u; } } For(u, 1, n){ if (getdist(dia1, u) > getdist(dia1, dia2)){ dia2 = u; } } int dia = getdist(dia1, dia2); int ans = INT_MAX; For(u, 0, n){ int d1 = getdist(u, dia1), d2 = getdist(u, dia2); int dd = (d1 + d2 - dia) / 2; d1 -= dd; d2 -= dd; ans = min(ans, max(d1, d2)); } return ans; // } return 0; } #ifdef FEXT signed main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); freopen("KEK.inp", "r", stdin); freopen("KEK.out", "w", stdout); int subtask, tests; cin >> subtask >> tests; while (tests--){ cin >> cac.n; For(i, 0, cac.n){ For(j, 0, cac.n){ cin >> cac.dist[i][j]; } } cout << hubDistance(cac.n, subtask) << endl; } } #endif /* ==================================================+ INPUT: | --------------------------------------------------| --------------------------------------------------| ==================================================+ OUTPUT: | --------------------------------------------------| --------------------------------------------------| ==================================================+ */

Compilation message (stderr)

towns.cpp: In function 'int {anonymous}::getdist(int, int)':
towns.cpp:57:24: warning: suggest parentheses around assignment used as truth value [-Wparentheses]
   57 |         if (dist[u][v] = -1){
      |             ~~~~~~~~~~~^~~~
towns.cpp: In function 'int hubDistance(int, int)':
towns.cpp:69:28: warning: unused parameter 'subtask' [-Wunused-parameter]
   69 | int hubDistance(int n, int subtask){
      |                        ~~~~^~~~~~~
#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...