Chess Knight

Chess Knight

Your friend loves chess very much, but he's not a strong player. You can help him by using your programming skills.
If this mission is too simple for you, try another one from this set - The shortest Knight's path.

There is only one figure on the board - your Knight. The input data will consist of a start cell and the maximum amount of moves that the Knight can make. Your task is to write a function that can find all of the chessboard cells to which the Knight can move at not more than maximum amount of moves (less is allowed).

If the same cell appears more than once - do not add it again. To count cell as reached, you need to move there from another cell. So, you will add start cell to reached, if you may return there from some other cell. "Zero" move is not counted: initial being in start cell doesn't mean, that it's reached by moving. You should return the list of all of the possible cells and sort them as follows: in alphabetical order (from 'a' to 'h') and in ascending order (from 'a1' to 'a8' and so on).

example

Input: A start cell, the number of moves.

Output: A list of all of the possible cells.

Example:

chess_knight('a1', 1) == ['b3', 'c2']
chess_knight('h8', 2) == ['d6', 'd8', 'e5', 'e7', 'f4', 'f7', 'f8', 'g5', 'g6', 'h4', 'h6', 'h8']

How it is used: For game analysis and bot (game AI) development.