-
"Safe Pawns" Review
Hi, Che..hm..ss lovers.
Today we will take a look at one of CheckiO's Chess missions "Safe Pawns". I hope you've heard about the ancient game Chess by now. In this mission we will take a closer look at the weakest but most numerous (and maybe even dangerous) chess piece: pawns.
A pawn is generally a weak unit, but we have 8 of them (sometimes less) which we can use to build a pawn defense wall. With this strategy, one pawn defends the other pieces. A pawn is safe if another pawn can capture a unit on that square. We have several white pawns on the chess board, and we only control the white pawns. You should design your code to find how many pawns are safe in the given scenario.
So our goal is to count safe pawns. For this we can check each of them for a defending neighbor. Each cell can have no more than two possible defending cells. The both of them are placed one line below, one in the left and one in the right column.
So pawn
is the cell coordinates for the checked pawn and rank is p[1]
. To find the
rank use str(int(p[1]) - 1)
or chr(ord(p[1]) - 1)
. To find left and right files we can use the
same method: chr(ord(p[0]) - 1)
and chr(ord(p[0]) + 1)
. Yes, I know that for
a1
we will get "`0" and "b0", but this is not a problem for our solution because we have a set
of correct pawn coordinates. So if we use the "wrong" coordinates, then we won't find them.
Now gather it into a function and, voilĂ , we have a solution:
After taking a look, almost all CiO player solutions are kinda same lookinh, so today I'll show you a neat one one-liner by @Juge_Ti (link)
That's all folks. Do you want me to review another specific mission? Then let me know in comment section below!