Submission #547820

#TimeUsernameProblemLanguageResultExecution timeMemory
547820MilosMilutinovicAliens (IOI07_aliens)C++14
10 / 100
3 ms464 KiB
#include <bits/stdc++.h> using namespace std; #define y0 y1231 #define y1 y132131 int n,x,y,x0,y0,x1,y1,x2,y2,x3,y3; bool Ask(int X,int Y){ printf("examine %d %d\n",X,Y); fflush(stdout); char s[6]; scanf("%s",s); return s[0]=='t'; } int main(){ scanf("%d%d%d",&n,&x,&y); { int low=0,high=x-1,ans=0; while(low<=high){ int mid=(low+high)/2; if(Ask(x-mid,y))ans=mid,low=mid+1; else high=mid-1; } x0=x-ans,y0=y; } { int low=0,high=n-x,ans=0; while(low<=high){ int mid=(low+high)>>1; if(Ask(x+mid,y))ans=mid,low=mid+1; else high=mid-1; } x1=x+ans,y1=y; } { int low=0,high=y-1,ans=0; while(low<=high){ int mid=(low+high)>>1; if(Ask(x,y-mid))ans=mid,low=mid+1; else high=mid-1; } x2=x,y2=y-ans; } { int low=0,high=n-y,ans=0; while(low<=high){ int mid=(low+high)>>1; if(Ask(x,y+mid))ans=mid,low=mid+1; else high=mid-1; } x3=x,y3=y+ans; } int lx=x1-x0+1,ly=y3-y2+1; for(int d:{1,3,5}){ if(lx%d!=0)continue; int m=lx/d; if(ly%m!=0||(ly/m!=1&&ly/m!=3&&ly/m!=5))continue; if(m%2==0)continue; int xl=x0,xr=x1,yl=y2,yr=y3; while(xl>m){ if(Ask(xl-m,y)||(y>m&&Ask(x1-m,y-m)||(y<=m&&y+m<=n&&Ask(x1-m,y+m))))xl-=m; else break; } while(xr+m<=n){ if(Ask(xr+m,y)||(y>m&&Ask(xr+m,y-m)||(y<=m&&y+m<=n&&Ask(xr+m,y+m))))xr+=m; else break; } while(yl>m){ if(Ask(x,yl-m)||(x>m&&Ask(x-m,yl-m)||(x<=m&&x+m<=n&&Ask(x+m,yl-m))))yl-=m; else break; } while(yr+m<=n){ if(Ask(x,yr+m)||(x>m&&Ask(x-m,yr+m)||(x<=m&&x+m<=n&&Ask(x+m,yr+m))))yr+=m; else break; } if(xr-xl+1==5*m&&yr-yl+1==5*m){ printf("solution %d %d",xl+2*m+m/2,yl+2*m+m/2); fflush(stdout); return 0; } } assert(false); return 0; }

Compilation message (stderr)

aliens.cpp: In function 'int main()':
aliens.cpp:59:24: warning: suggest parentheses around '&&' within '||' [-Wparentheses]
   59 |    if(Ask(xl-m,y)||(y>m&&Ask(x1-m,y-m)||(y<=m&&y+m<=n&&Ask(x1-m,y+m))))xl-=m;
      |                     ~~~^~~~~~~~~~~~~~~
aliens.cpp:63:24: warning: suggest parentheses around '&&' within '||' [-Wparentheses]
   63 |    if(Ask(xr+m,y)||(y>m&&Ask(xr+m,y-m)||(y<=m&&y+m<=n&&Ask(xr+m,y+m))))xr+=m;
      |                     ~~~^~~~~~~~~~~~~~~
aliens.cpp:67:24: warning: suggest parentheses around '&&' within '||' [-Wparentheses]
   67 |    if(Ask(x,yl-m)||(x>m&&Ask(x-m,yl-m)||(x<=m&&x+m<=n&&Ask(x+m,yl-m))))yl-=m;
      |                     ~~~^~~~~~~~~~~~~~~
aliens.cpp:71:24: warning: suggest parentheses around '&&' within '||' [-Wparentheses]
   71 |    if(Ask(x,yr+m)||(x>m&&Ask(x-m,yr+m)||(x<=m&&x+m<=n&&Ask(x+m,yr+m))))yr+=m;
      |                     ~~~^~~~~~~~~~~~~~~
aliens.cpp: In function 'bool Ask(int, int)':
aliens.cpp:10:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   10 |  scanf("%s",s);
      |  ~~~~~^~~~~~~~
aliens.cpp: In function 'int main()':
aliens.cpp:14:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   14 |  scanf("%d%d%d",&n,&x,&y);
      |  ~~~~~^~~~~~~~~~~~~~~~~~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...