Submission #1007399

#TimeUsernameProblemLanguageResultExecution timeMemory
1007399tosivanmakRail (IOI14_rail)C++17
0 / 100
57 ms197980 KiB
#include "rail.h" #include<bits/stdc++.h> using namespace std; #define ll long long #define pb push_back ll dist[5005][5005]; ll loc[1000005]; ll getdist(ll i, ll j){ if(i==j)return 0; if(dist[i][j])return dist[i][j]; dist[i][j]=dist[j][i]=getDistance(i,j); return dist[i][j]; } void findLocation(int n, int first, int location[],int stype[]){ location[0]=first,stype[0]=1; loc[first]=0; if(n==1)return; int st=0; vector<pair<ll,ll> >from,hi,mi; for(int i=1;i<n;i++){ from.pb({getdist(st,i),i}); } sort(from.begin(),from.end()); ll req=from[0].second; location[req]=location[0]+getdist(0,req);stype[req]=2; for(int i=0;i<n;i++){ if(i==st||i==req)continue; if(getdist(st,i)==getdist(req,i)+getdist(st,req)&&getdist(req,i)<getdist(st,req)){ stype[i]=1;location[i]=location[req]-getdist(req,i);continue; } if(getdist(st,i)==getdist(req,i)+getdist(st,req)){ hi.push_back({getdist(req,i),i}); } else{ mi.push_back({getdist(st,i),i}); } } sort(hi.begin(),hi.end()); sort(mi.begin(),mi.end()); ll init,init2; for(int i=0;i<hi.size();i++){ ll nd=hi[i].second; ll v=getdist(init,nd)+getdist(req,nd)-getdist(init,req);v/=2; if(location[init]+getdist(init,nd)-v!=location[init]){ location[nd]=location[req]-getdist(req,nd); stype[nd]=1; } else{ location[nd]=location[init]+v; stype[nd]=2;init=nd; } } for(int i=0;i<mi.size();i++){ ll nd=mi[i].second; ll v=getdist(init,nd)+getdist(st,nd)-getdist(init,st);v/=2; if(location[init]-getdist(init,nd)+v!=location[init]){ location[nd]=location[st]+getdist(st,nd); stype[nd]=2; } else{ location[nd]=location[init]-v; stype[nd]=1;init=nd; } } } // int main() // { // int i; // getInput(); // cnt = 0; // int location[10005]; // int type[10005]; // int ok = 1; // findLocation(S, serverGetFirstStationLocation(),location, type); // if(SUBTASK==3 && cnt>S*(S-1)) ok = 0; // if(SUBTASK==4 && cnt>3*(S-1)) ok = 0; // for (i = 0; i < S; i++){ // cout<<type[i]<<" "<<location[i]<<'\n'; // } // if(ok==0) printf("Incorrect"); // else printf("Correct"); // return 0; // }

Compilation message (stderr)

rail.cpp: In function 'void findLocation(int, int, int*, int*)':
rail.cpp:42:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   42 |     for(int i=0;i<hi.size();i++){
      |                 ~^~~~~~~~~~
rail.cpp:54:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, long long int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   54 |     for(int i=0;i<mi.size();i++){
      |                 ~^~~~~~~~~~
rail.cpp:41:13: warning: unused variable 'init2' [-Wunused-variable]
   41 |     ll init,init2;
      |             ^~~~~
rail.cpp:12:38: warning: 'init' may be used uninitialized in this function [-Wmaybe-uninitialized]
   12 |     dist[i][j]=dist[j][i]=getDistance(i,j);
      |                           ~~~~~~~~~~~^~~~~
rail.cpp:41:8: note: 'init' was declared here
   41 |     ll init,init2;
      |        ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...