Enable Javascript in your browser and then refresh this page, for a much enhanced experience.
First time oop + recursion solution in Creative category for The Warriors by jktujgxtu
class Warrior:
hp = 50
atk = 5
is_alive = True
class Knight(Warrior):
atk = 7
count = 0
def fight(unit_1, unit_2):
global count
count += 1
if not(unit_1.hp > 0 and unit_1.hp > 0):
if not count % 2 :
unit_1, unit_2 = unit_2, unit_1
unit_1.is_alive = unit_1.hp > 0
unit_2.is_alive = unit_2.hp > 0
count = 0
return unit_1.is_alive
else:
unit_2.hp -= unit_1.atk
return fight(unit_2, unit_1)
if __name__ == '__main__':
#These "asserts" using only for self-checking and not necessary for auto-testing
chuck = Warrior()
bruce = Warrior()
carl = Knight()
dave = Warrior()
mark = Warrior()
assert fight(chuck, bruce) == True
assert fight(dave, carl) == False
assert chuck.is_alive == True
assert bruce.is_alive == False
assert carl.is_alive == True
assert dave.is_alive == False
assert fight(carl, mark) == False
assert carl.is_alive == False
print("Coding complete? Let's try tests!")
March 30, 2019
Comments: