結果

問題 No.240 ナイト散歩
ユーザー fine
提出日時 2015-10-18 23:16:35
言語 Ruby
(3.4.1)
結果
AC  
実行時間 88 ms / 2,000 ms
コード長 796 bytes
コンパイル時間 109 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-10-07 21:13:47
合計ジャッジ時間 3,918 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 30
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

def knight(x,y,n)
	case n
	when 0
		x -= 2
		y -= 1
	when 1
		x -= 2
		y += 1
	when 2
		x -= 1
		y -= 2
	when 3
		x -= 1
		y += 2
	when 4
		x += 1
		y -= 2
	when 5
		x += 1
		y += 2
	when 6
		x += 2
		y -= 1
	when 7
		x += 2
		y += 1
	end
	return x,y
end

X,Y = gets.split.map(&:to_i)
x = y = tmp1_x = tmp1_y = tmp2_x = tmp2_y = 0
if X.abs > 6 || Y.abs > 6
	puts "NO"
else
	8.times{|i|
		x = y = 0
		tmp1_x,tmp1_y = knight(x,y,i)
		x,y = tmp1_x,tmp1_y
		if x == X && y == Y
			puts "YES"
			exit
		end
		8.times{|j|
			x,y = tmp1_x,tmp1_y
			tmp2_x,tmp2_y = knight(x,y,j)
			x,y = tmp2_x,tmp2_y
			if x == X && y == Y
				puts "YES"
				exit
			end
			8.times{|k|
				x,y = tmp2_x,tmp2_y
				x,y = knight(x,y,k)
				if x == X && y == Y
					puts "YES"
					exit
				end
			}
		}
	}
	puts "NO"
end
0