| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 1 초 | 2048 MB | 55 | 49 | 35 | 89.744% |
Before we get into the problem, let's go over algebraic notation in chess. Algebraic notation refers to the "names" of the squares on a chessboard. Starting from left to right (from white's perspective), the columns are named a--h. The rows are then named 1ドル$--8ドル$ in increasing order (again from white's perspective). Each square's "name" is the column letter followed by the row number of that particular square.
In chess, a knight's move is unique. It may move two squares horizontally and one square vertically, or two squares vertically and one square horizontally (with both forming the shape of an L). For example, a knight on d3 can move to c1, b2, b4, c5, e5, f4, f2, and e1.
Your task is as follows: given the position of a knight on a chessboard in algebraic notation, output all of the knight's possible moves.
The first (and only) line of input is the location of the knight in algebraic notation. It is guaranteed that it will be a valid square on an 8ドル \times 8$ chessboard.
Output all of the knight's possible moves in lexicographic order, with each square on its own line. Lexicographic order is a generalization of alphabetical order that means c1 comes before d1, a1 comes before a2, etc.
a1
b3 c2
d3
b2 b4 c1 c5 e1 e5 f2 f4
School > CS@Mines > CS@Mines HSPC 2022 > Beginner B번