結果
問題 | No.61 リベリオン |
ユーザー | kotatsugame |
提出日時 | 2020-02-28 00:53:40 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 43 ms / 5,000 ms |
コード長 | 747 bytes |
コンパイル時間 | 705 ms |
コンパイル使用メモリ | 65,544 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-13 16:16:54 |
合計ジャッジ時間 | 1,161 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,248 KB |
testcase_02 | AC | 2 ms
5,248 KB |
testcase_03 | AC | 43 ms
5,248 KB |
testcase_04 | AC | 42 ms
5,248 KB |
testcase_05 | AC | 2 ms
5,248 KB |
コンパイルメッセージ
main.cpp:7:1: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type] 7 | main() | ^~~~
ソースコード
#include<iostream> using namespace std; int Q; bool vis[4][16][16]; int X,Y,D,Mx,My,Hx,Hy,Vx,Vy; int gcd(int a,int b){return b?gcd(b,a%b):a;} main() { cin>>Q; for(;Q--;) { cin>>X>>Y>>D>>Mx>>My>>Hx>>Hy>>Vx>>Vy; int g=gcd(Vx>0?Vx:-Vx,Vy>0?Vy:-Vy); Vx/=g; Vy/=g; D*=g; for(int r=0;r<4;r++)for(int i=0;i<=X;i++)for(int j=0;j<=Y;j++)vis[r][i][j]=false; int x=Hx,y=Hy,r=0; for(D++;D--&&!vis[r][x][y];) { vis[r][x][y]=true; x+=r&1?-Vx:Vx; y+=r&2?-Vy:Vy; while(x<0||x>X) { if(x<0)x=-x,r^=1; else if(x>X)x=X-(x-X),r^=1; } while(y<0||y>Y) { if(y<0)y=-y,r^=2; else if(y>Y)y=Y-(y-Y),r^=2; } } bool ans=false; for(int r=0;r<4;r++)ans|=vis[r][Mx][My]; cout<<(ans?"Hit":"Miss")<<endl; } }