Submission #18834

#TimeUsernameProblemLanguageResultExecution timeMemory
18834ggohIdeal city (IOI12_city)C++98
11 / 100
1000 ms262144 KiB
#include<cstdio> #include<map> #include<queue> int a,x,y,p,q,i,j,dx[]={1,0,-1,0},dy[]={0,1,0,-1}; long long sum,mod=1e9; std::map<int,int>m[2002],D[2002][2002]; std::queue<int>P,Q; int DistanceSum (int N, int *X, int *Y) { a=N; x=2147483647;y=2147483647; for(i=0;i<a;i++)x=std::min(x,X[i]),y=std::min(y,Y[i]); for(i=0;i<a;i++)X[i]-=x,Y[i]-=y,m[X[i]][Y[i]]=1; for(i=0;i<a;i++) { P.push(X[i]); Q.push(Y[i]); D[i][X[i]][Y[i]]=1;sum++; while(!P.empty()) { p=P.front();P.pop();q=Q.front();Q.pop(); for(int k=0;k<4;k++) { x=p+dx[k];y=q+dy[k]; if(x>=0&&y>=0&&m[x][y]&&D[i][x][y]==0) { D[i][x][y]=D[i][p][q]+1; sum+=D[i][x][y]; P.push(x);Q.push(y); } } } sum-=a; } sum/=(long long)2; return sum%mod; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...