Enable Javascript in your browser and then refresh this page, for a much enhanced experience.
pwnd solution in Speedy category for Pawn Brotherhood by tarikki
def safe_pawns(pawns):
safe = 0
pp = [] #possible protectors
for pawn in pawns:
pp.append(chr(ord(pawn[0])-1)+str(int(pawn[1])-1)) #a possible protector would be one down the alphabet, one line down
pp.append(chr(ord(pawn[0])+1)+str(int(pawn[1])-1)) #or one up the alphabet, one line down
if any(p in pawns for p in pp): #if the list of pawns has any of these two,
safe += 1 #the pawn in question is safe
pp = [] #remember to reset the list
return safe
if __name__ == '__main__':
#These "asserts" using only for self-checking and not necessary for auto-testing
assert safe_pawns({"b4", "d4", "f4", "c3", "e3", "g5", "d2"}) == 6
assert safe_pawns({"b4", "c4", "d4", "e4", "f4", "g4", "e5"}) == 1
Aug. 17, 2014
Comments: