結果
問題 | No.240 ナイト散歩 |
ユーザー |
![]() |
提出日時 | 2017-05-02 09:32:51 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 981 bytes |
コンパイル時間 | 954 ms |
コンパイル使用メモリ | 82,568 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-07 21:38:11 |
合計ジャッジ時間 | 2,048 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 30 |
ソースコード
#define ll long long#define ffor(i,a,b) for (int i=(a);i<(b);i++)#define rfor(i,a,b) for (int i=(b)-1;i>=(a);i--)#define rep(i,n) for (int i=0;i<(n);i++)#define rrep(i,n) for (int i=(n)-1;i>=0;i--)#include<iostream>#include<iomanip>#include<algorithm>#include<cmath>#include<string>#include<stack>#include<queue>#define SIZE 100001#define MOD 1000000007#define INF 100000000using namespace std;typedef pair<int,int> P;int dx[8] = {-2,-2,-1,-1,1,1,2,2};int dy[8] = {-1,1,-2,2,-2,2,-1,1};int main(){int flag = 0;int x,y;cin >> x >> y;queue <P> q;queue <int> num;q.push(P(0,0));num.push(0);while(!q.empty()){P now = q.front();int count = num.front();q.pop();num.pop();if(count >= 3) continue;rep(i,8){int a = now.first + dx[i];int b = now.second + dy[i];if(a == x && b == y){flag = 1;break;}q.push(P(a,b));num.push(count+1);}}cout << ((flag==1)? "YES":"NO") << endl;return 0;}