Problem hidden
|This problem was hidden by Editorial Board member probably because it has incorrect language|version or invalid test data, or description of the problem is not clear.|

RGB7785 - Шатрын L морь

L-Морь (KnightL) бол L хэлбэрээр нүүдэг шатрын дүрс юм. 

Бид KnightL(a,b) гэдгээр  (x1, y1) байрлалаас (x2, y2) байрлалд хүрэх боломжит нүүдлүүдийн тоог тодорхойльё.

  • x2 = x1 ± a , y2 = y1 ± b   юм уу
  • x2 = x1 ± b , y2 = y1 ± a хэлбэрээр нүүнэ.

Энд (a, b) болон (b,a) гэсэн нүүдэл нь нэг ижил хэлбэрийн нүүдлүүд гэдгийг анзаараарай.

Жишээлбэл

5 х 5 хэмжээтэй шатрын хөлгийн төв дээр байгаа L-морины KnightL(2, 1) юм уу KnightL(1, 2)

гэсэн нүүдлүүд нь нэгэн төрлийн нүүдэл болох нь харагдаж байна.

image

Энэ нь аль нэг чиглэлд 2 нүд шилжээд, перпендикуляр чиглэлд 1 нүд шилжиж байгаа нь ажиглагдаж байна.

Өгөгдсөн n x n шатрын хөлгийн хувьд (a, b) хос бүрийн хувьд (1 <= a, b <n) L-морь KnightL(a, b) нүүдлээр 

(0, 0) байрлалаас  (n-1, n-1) байрлалд хүрэх хамгийн цөөн нүүдлийн тоог тодорхойлно уу?

Хэрвээ тухайн нүдэнд очих очих боломжгүй бол -1 байна. Тэгвэл (a, b) бүрийн хувьд KnightL(a, b) асуултанд хариулна уу?

Оролтын хэлбэр:

Шатрын хөлгийн хэмжээ болох n тоо өгөгдөнө.

Хязгаарлалт:

5 <= n <= 25

Гаралтын хэлбэр:

n-1 ширхэг мөр, n-1 ширхэг багананд бүх боломжит (i, j) –ийн хувьд Knight(i, j) нүүдлээр (n-1, n-1)

нүдэнд очих боломжит хамгийн цөөн нүүдлийн тоог (i, j)  нүдэнд хэвлэнэ үү?

Хэрвээ тухайн нүдэнд очих боломжгүй бол -1 гэж хэвлэнэ үү?

Жишээлбэл n = 3 үед боломжит (i, j) хосууд нь

(1, 1), (1,2)

(2,1), (2,2) гэсэн хэлбэртэй байна.

Жишээ оролт 0

5

Жишээ гаралт 0

4 4 2 8

4 2 4 4

2 4 -1 -1

8 4 -1 1

Тайлбар 0

Дараах зурган дээр KnightL(1, 1),  KnightL(1, 2), KnightL(1, 3) хэлбэрийн 

image

нүүдлүүдийг харуулсан байна.

Харин KnightL(1,4) хэлбэрийн нүүдлийн хувьд хамгийн цөөн нүүдлүүдийн нэг нь дараах хэлбэртэй байна.

(0 ,0) -> (1, 4) -> (2, 0) -> (3, 4) -> (4, 0) -> (0, 1) -> (4, 2) -> (0,3) -> (4,4) гэсэн дарааллаар буюу

хамгийн цөөндөө нийт 8 удаа нүүж тухайн нүдэнд очиж байна.

Тийм учраас гаралтын файлын эхний мөрөнд  KnightL(1, 1) = 4,  KnightL(1, 2) = 4, KnightL(1, 3) = 2, KnightL(1, 4) = 8

буюу 4 4 2 8 гэж хэвлэсэн байна.

Энэ мэтчилэн дараагийн нүднүүдэд тухайн (i, j) тооны буюу KnightL(i ,j) хэлбэрийн нүүдлээр очиж болох

хамгийн цөөн нүүдлийн тоонуудыг хэвлэнэ.

Жишээ нь

(0,0) байрлалаас KnightL(3, 3) байдлаар хэзээ ч (4, 4) нүдэнд очих боломжгүй учраас (3,3) нүдэнд -1 байна.

 

Орчуулсан : Хөвсгөл аймгийн Ирээдүй сургуулийн багш Д.Батмөнх 


Нэмсэн:Bataa
Огноо:2020-04-06
Хугацааны хязгаарлалт:1s
Эх кодын хэмжээний хязгаарлалт:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Програмчлалын хэлүүд:ADA95 ASM32 ASM64 BASH BF C NCSHARP CSHARP C++ 4.3.2 CPP C99 CLPS LISP sbcl LISP clisp D ERL FORTRAN HASK ICON ICK JAVA JS-RHINO JULIA LUA NEM NICE OCAML PAS-GPC PAS-FPC PERL PHP PIKE PRLG-swi PYTHON PYPY3 PYTHON3 RUBY SCALA SCM guile ST TCL WHITESPACE
Эх сурвалж:https://www.hackerrank.com/challenges/knightl-on-chessboard/problem

hide comments
2022-05-20 06:54:32
muu teneg
2022-02-15 14:49:59
100% tentssen baisan chin bi 2 udaa aldaad 60% bolgoson. Uneheer uuchlaarai
© Spoj.com. All Rights Reserved. Spoj uses Sphere Engine™ © by Sphere Research Labs.