Hide

Problem B
Knights Move

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.

/problems/mines22.knightsmove/file/statement/en/img-0001.png
Photo retrieved from wikipedia.org. Image Source

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.

Input

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

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.

Sample Input 1 Sample Output 1
a1
b3
c2
Sample Input 2 Sample Output 2
d3
b2
b4
c1
c5
e1
e5
f2
f4

Please log in to submit a solution to this problem

Log in