✨ Finishing 11 new elements
This commit is contained in:
parent
da0609f315
commit
1dcfd757e8
26
Incinerator/rotate-hole.py
Normal file
26
Incinerator/rotate-hole.py
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
def rotate(state, pipe_numbers):
|
||||||
|
count = []
|
||||||
|
for i in range(len(state)):
|
||||||
|
last = state.pop()
|
||||||
|
state.insert(0, last)
|
||||||
|
is_good = True
|
||||||
|
for j in pipe_numbers:
|
||||||
|
if state[j] != 1:
|
||||||
|
is_good = False
|
||||||
|
break
|
||||||
|
if is_good:
|
||||||
|
if i+1 >= len(state):
|
||||||
|
count.append(0)
|
||||||
|
else:
|
||||||
|
count.append(i+1)
|
||||||
|
count.sort()
|
||||||
|
print(count)
|
||||||
|
return count
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
assert rotate([1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1], [0, 1]) == [1, 8], "Example"
|
||||||
|
assert rotate([1, 0, 0, 0, 1, 1, 0, 1, 0, 0, 0, 1], [0, 1, 2]) == [], "Mission impossible"
|
||||||
|
assert rotate([1, 0, 0, 0, 1, 1, 0, 1], [0, 4, 5]) == [0], "Don't touch it"
|
||||||
|
assert rotate([1, 0, 0, 0, 1, 1, 0, 1], [5, 4, 5]) == [0, 5], "Two cannonballs in the same pipe"
|
161
Incinerator/the-lancers.py
Normal file
161
Incinerator/the-lancers.py
Normal file
@ -0,0 +1,161 @@
|
|||||||
|
# Taken from mission The Vampires
|
||||||
|
# Taken from mission The Defenders
|
||||||
|
# Taken from mission Army Battles
|
||||||
|
# Taken from mission The Warriors
|
||||||
|
|
||||||
|
|
||||||
|
class Warrior:
|
||||||
|
def __init__(self):
|
||||||
|
self.health = 50
|
||||||
|
self.attack = 5
|
||||||
|
self.is_alive = True
|
||||||
|
self.defense = 0
|
||||||
|
self.vampirism = 0
|
||||||
|
|
||||||
|
def hit(self, other_unit) -> bool:
|
||||||
|
hit_points = self.attack - other_unit.defense
|
||||||
|
hit_points = hit_points if hit_points > 0 else 0
|
||||||
|
other_unit.health -= hit_points
|
||||||
|
other_unit.is_alive = other_unit.health > 0
|
||||||
|
|
||||||
|
self.health += (hit_points * self.vampirism)
|
||||||
|
return other_unit.is_alive
|
||||||
|
|
||||||
|
|
||||||
|
class Knight(Warrior):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.attack = 7
|
||||||
|
|
||||||
|
|
||||||
|
class Defender(Warrior):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.health = 60
|
||||||
|
self.attack = 3
|
||||||
|
self.defense = 2
|
||||||
|
|
||||||
|
|
||||||
|
class Vampire(Warrior):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.health = 40
|
||||||
|
self.attack = 4
|
||||||
|
self.vampirism = 0.5
|
||||||
|
|
||||||
|
|
||||||
|
class Rookie(Warrior):
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
super().__init__()
|
||||||
|
self.health = 50
|
||||||
|
self.attack = 1
|
||||||
|
|
||||||
|
|
||||||
|
class Lancer(Warrior):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.attack = 6
|
||||||
|
|
||||||
|
|
||||||
|
def fight(unit_1, unit_2):
|
||||||
|
while unit_1.is_alive and unit_2.is_alive:
|
||||||
|
if not unit_1.hit(unit_2):
|
||||||
|
return True
|
||||||
|
if not unit_2.hit(unit_1):
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
class Army:
|
||||||
|
def __init__(self):
|
||||||
|
self.units = []
|
||||||
|
|
||||||
|
def add_units(self, unit_type, quantity):
|
||||||
|
for i in range(quantity):
|
||||||
|
self.units.append(unit_type())
|
||||||
|
|
||||||
|
|
||||||
|
class Battle:
|
||||||
|
@staticmethod
|
||||||
|
def fight(army_1: Army, army_2: Army) -> bool:
|
||||||
|
while len(army_1.units) > 0 and len(army_2.units) > 0:
|
||||||
|
current_unit_1 = army_1.units[0]
|
||||||
|
current_unit_2 = army_2.units[0]
|
||||||
|
while current_unit_1.is_alive and current_unit_2.is_alive:
|
||||||
|
current_unit_1_attack = current_unit_1.hit(current_unit_2)
|
||||||
|
if isinstance(current_unit_1, Lancer) and len(army_2.units) > 1:
|
||||||
|
army_2.units[1].health -= current_unit_1.attack * 0.5
|
||||||
|
if not current_unit_1_attack:
|
||||||
|
army_2.units.pop(0)
|
||||||
|
break
|
||||||
|
current_unit_2_attack = current_unit_2.hit(current_unit_1)
|
||||||
|
if isinstance(current_unit_2, Lancer) and len(army_1.units) > 1:
|
||||||
|
army_1.units[1].health -= current_unit_2.attack * 0.5
|
||||||
|
if not current_unit_2_attack:
|
||||||
|
army_1.units.pop(0)
|
||||||
|
break
|
||||||
|
return len(army_1.units) > 0
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
|
||||||
|
# fight tests
|
||||||
|
chuck = Warrior()
|
||||||
|
bruce = Warrior()
|
||||||
|
carl = Knight()
|
||||||
|
dave = Warrior()
|
||||||
|
mark = Warrior()
|
||||||
|
bob = Defender()
|
||||||
|
mike = Knight()
|
||||||
|
rog = Warrior()
|
||||||
|
lancelot = Defender()
|
||||||
|
eric = Vampire()
|
||||||
|
adam = Vampire()
|
||||||
|
richard = Defender()
|
||||||
|
ogre = Warrior()
|
||||||
|
freelancer = Lancer()
|
||||||
|
vampire = Vampire()
|
||||||
|
|
||||||
|
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
|
||||||
|
assert fight(bob, mike) == False
|
||||||
|
assert fight(lancelot, rog) == True
|
||||||
|
assert fight(eric, richard) == False
|
||||||
|
assert fight(ogre, adam) == True
|
||||||
|
assert fight(freelancer, vampire) == True
|
||||||
|
assert freelancer.is_alive == True
|
||||||
|
|
||||||
|
# battle tests
|
||||||
|
my_army = Army()
|
||||||
|
my_army.add_units(Defender, 2)
|
||||||
|
my_army.add_units(Vampire, 2)
|
||||||
|
my_army.add_units(Lancer, 4)
|
||||||
|
my_army.add_units(Warrior, 1)
|
||||||
|
|
||||||
|
enemy_army = Army()
|
||||||
|
enemy_army.add_units(Warrior, 2)
|
||||||
|
enemy_army.add_units(Lancer, 2)
|
||||||
|
enemy_army.add_units(Defender, 2)
|
||||||
|
enemy_army.add_units(Vampire, 3)
|
||||||
|
|
||||||
|
army_3 = Army()
|
||||||
|
army_3.add_units(Warrior, 1)
|
||||||
|
army_3.add_units(Lancer, 1)
|
||||||
|
army_3.add_units(Defender, 2)
|
||||||
|
|
||||||
|
army_4 = Army()
|
||||||
|
army_4.add_units(Vampire, 3)
|
||||||
|
army_4.add_units(Warrior, 1)
|
||||||
|
army_4.add_units(Lancer, 2)
|
||||||
|
|
||||||
|
battle = Battle()
|
||||||
|
|
||||||
|
assert battle.fight(my_army, enemy_army) == True
|
||||||
|
assert battle.fight(army_3, army_4) == False
|
||||||
|
print("Coding complete? Let's try tests!")
|
30
Mine/caesar-cipher-encryptor.py
Normal file
30
Mine/caesar-cipher-encryptor.py
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
import string
|
||||||
|
|
||||||
|
|
||||||
|
def to_encrypt(text, delta):
|
||||||
|
alphabet = list(string.ascii_lowercase)
|
||||||
|
new_text = []
|
||||||
|
for letter in text:
|
||||||
|
if letter.isalpha():
|
||||||
|
letter_index = alphabet.index(letter) + delta
|
||||||
|
if letter_index > len(alphabet):
|
||||||
|
letter_index = letter_index - len(alphabet)
|
||||||
|
if letter_index < 0:
|
||||||
|
letter_index = len(alphabet) + letter_index
|
||||||
|
new_text.append(alphabet[letter_index])
|
||||||
|
else:
|
||||||
|
new_text.append(letter)
|
||||||
|
return "".join(new_text)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
print("Example:")
|
||||||
|
print(to_encrypt('abc', 10))
|
||||||
|
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
assert to_encrypt("a b c", 3) == "d e f"
|
||||||
|
assert to_encrypt("a b c", -3) == "x y z"
|
||||||
|
assert to_encrypt("simple text", 16) == "iycfbu junj"
|
||||||
|
assert to_encrypt("important text", 10) == "swzybdkxd dohd"
|
||||||
|
assert to_encrypt("state secret", -13) == "fgngr frperg"
|
||||||
|
print("Coding complete? Click 'Check' to earn cool rewards!")
|
28
Mine/morse-encoder.py
Normal file
28
Mine/morse-encoder.py
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
MORSE = {'a': '.-', 'b': '-...', 'c': '-.-.',
|
||||||
|
'd': '-..', 'e': '.', 'f': '..-.',
|
||||||
|
'g': '--.', 'h': '....', 'i': '..',
|
||||||
|
'j': '.---', 'k': '-.-', 'l': '.-..',
|
||||||
|
'm': '--', 'n': '-.', 'o': '---',
|
||||||
|
'p': '.--.', 'q': '--.-', 'r': '.-.',
|
||||||
|
's': '...', 't': '-', 'u': '..-',
|
||||||
|
'v': '...-', 'w': '.--', 'x': '-..-',
|
||||||
|
'y': '-.--', 'z': '--..', '0': '-----',
|
||||||
|
'1': '.----', '2': '..---', '3': '...--',
|
||||||
|
'4': '....-', '5': '.....', '6': '-....',
|
||||||
|
'7': '--...', '8': '---..', '9': '----.'
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def morse_encoder(text):
|
||||||
|
return " ".join([MORSE[letter] if letter in MORSE.keys() else " " for letter in text.lower()])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
print("Example:")
|
||||||
|
print(morse_encoder('some text'))
|
||||||
|
'... --- -- . - . -..- -'
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
assert morse_encoder("some text") == "... --- -- . - . -..- -"
|
||||||
|
assert morse_encoder("2018") == "..--- ----- .---- ---.."
|
||||||
|
assert morse_encoder("It was a good day") == ".. - .-- .- ... .- --. --- --- -.. -.. .- -.--"
|
||||||
|
print("Coding complete? Click 'Check' to earn cool rewards!")
|
28
Mine/skew-symmetric-matrix.py
Normal file
28
Mine/skew-symmetric-matrix.py
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
def checkio(matr):
|
||||||
|
clone = zip(*matr)
|
||||||
|
modifiedClone = []
|
||||||
|
for row in clone:
|
||||||
|
modifiedClone.append(list(map(mult, row)))
|
||||||
|
|
||||||
|
for i, row in enumerate(matr):
|
||||||
|
for j, cell in enumerate(matr[i]):
|
||||||
|
if cell != modifiedClone[i][j]:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
def mult(e):
|
||||||
|
return -1 * e
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
assert checkio([[0, 1, 2],
|
||||||
|
[-1, 0, 1],
|
||||||
|
[-2, -1, 0]]) == True, 'First'
|
||||||
|
assert checkio([[0, 1, 2],
|
||||||
|
[-1, 1, 1],
|
||||||
|
[-2, -1, 0]]) == False, 'Second'
|
||||||
|
assert checkio([[0, 1, 2],
|
||||||
|
[-1, 0, 1],
|
||||||
|
[-3, -1, 0]]) == False, 'Third'
|
||||||
|
print('All ok')
|
34
Polygon/create-intervals-iterator-version.py
Normal file
34
Polygon/create-intervals-iterator-version.py
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
def create_intervals(data):
|
||||||
|
"""
|
||||||
|
Create a list of intervals out of set of ints.
|
||||||
|
"""
|
||||||
|
results = []
|
||||||
|
data = sorted(data)
|
||||||
|
start = None
|
||||||
|
current_number = None
|
||||||
|
for number in data:
|
||||||
|
if start is None:
|
||||||
|
start = number
|
||||||
|
current_number = start
|
||||||
|
continue
|
||||||
|
if number != start and number != (current_number + 1):
|
||||||
|
results.append((start, current_number))
|
||||||
|
start = number
|
||||||
|
current_number = number
|
||||||
|
if start is not None:
|
||||||
|
results.append((start, current_number))
|
||||||
|
return iter(results)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
res = create_intervals(iter(sorted(list({1, 2, 3, 4, 5, 7, 8, 12}))))
|
||||||
|
assert hasattr(res, '__iter__'), "your function should return the iterator object"
|
||||||
|
assert hasattr(res, '__next__'), "your function should return the iterator object"
|
||||||
|
|
||||||
|
assert list(create_intervals(iter(sorted(list({1, 2, 3, 4, 5, 7, 8, 12}))))) == [
|
||||||
|
(1, 5), (7, 8), (12, 12)], "First"
|
||||||
|
assert list(create_intervals(iter(sorted(list({1, 2, 3, 6, 7, 8, 4, 5}))))) == [
|
||||||
|
(1, 8)], "Second"
|
||||||
|
assert list(create_intervals(iter([]))) == [], "Empty"
|
||||||
|
print('Almost done! The only thing left to do is to Check it!')
|
25
Polygon/flatten-a-list-iterator-version.py
Normal file
25
Polygon/flatten-a-list-iterator-version.py
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
def flat_list(array):
|
||||||
|
return iter(flat_iter(array))
|
||||||
|
|
||||||
|
|
||||||
|
def flat_iter(array):
|
||||||
|
new_array = []
|
||||||
|
for i in array:
|
||||||
|
if hasattr(i, '__next__'):
|
||||||
|
new_array += flat_iter(i)
|
||||||
|
else:
|
||||||
|
new_array.append(i)
|
||||||
|
return new_array
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
res = flat_list([1, 2, 3])
|
||||||
|
assert hasattr(res, '__iter__'), "your function should return the iterator object"
|
||||||
|
assert hasattr(res, '__next__'), "your function should return the iterator object"
|
||||||
|
|
||||||
|
assert list(flat_list(iter([1, 2, 3]))) == [1, 2, 3], "First"
|
||||||
|
assert list(flat_list(iter([1, iter([2, 2, 2]), 4]))) == [1, 2, 2, 2, 4], "Second"
|
||||||
|
assert list(flat_list(iter([iter([2]), iter([4, iter([5, 6, iter([6]), 6, 6, 6]), 7])]))) == [2, 4, 5, 6, 6, 6, 6,
|
||||||
|
6, 7], "Third"
|
||||||
|
assert list(flat_list(iter([-1, iter([1, iter([-2]), 1]), -1]))) == [-1, 1, -2, 1, -1], "Four"
|
||||||
|
print('Done! Check it')
|
27
Polygon/most-wanted-letter-2.py
Normal file
27
Polygon/most-wanted-letter-2.py
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
def most_wanted(text: str) -> str:
|
||||||
|
text = text.lower()
|
||||||
|
letters = []
|
||||||
|
max = 0
|
||||||
|
for letter in text:
|
||||||
|
if letter.isalpha():
|
||||||
|
if letter not in letters:
|
||||||
|
count = text.count(letter)
|
||||||
|
if max == count:
|
||||||
|
letters.append(letter)
|
||||||
|
if count > max:
|
||||||
|
letters = [letter]
|
||||||
|
max = count
|
||||||
|
return letters
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
assert sorted(most_wanted("Hello World!")) == ["l"], "Hello test"
|
||||||
|
assert sorted(most_wanted("How do you do?")) == ["o"], "O is most wanted"
|
||||||
|
assert sorted(most_wanted("One")) == ["e", "n", "o"], "All letter only once."
|
||||||
|
assert sorted(most_wanted("Oops!")) == ["o"], "Don't forget about lower case."
|
||||||
|
assert sorted(most_wanted("AAaooo!!!!")) == ["a", "o"], "Only letters."
|
||||||
|
assert sorted(most_wanted("abe")) == ["a", "b", "e"], "The First."
|
||||||
|
print("Start the long test")
|
||||||
|
assert sorted(most_wanted("a" * 9000 + "b" * 1000)) == ["a"], "Long."
|
||||||
|
print("The local tests are done.")
|
17
PyconTW/matrix-transpose.py
Normal file
17
PyconTW/matrix-transpose.py
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
def checkio(matr):
|
||||||
|
"""return a transposed matrix"""
|
||||||
|
return map(list, zip(*matr))
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
assert checkio([[1, 2],
|
||||||
|
[1, 2]]) == [[1, 1],
|
||||||
|
[2, 2]], 'First'
|
||||||
|
assert checkio([[1, 0, 3, 4, 0],
|
||||||
|
[2, 0, 4, 5, 6],
|
||||||
|
[3, 4, 9, 0, 6]]) == [[1, 2, 3],
|
||||||
|
[0, 0, 4],
|
||||||
|
[3, 4, 9],
|
||||||
|
[4, 5, 0],
|
||||||
|
[0, 6, 6]], 'Second'
|
||||||
|
print('All ok')
|
13
PyconTW/simple_hashlib.py
Normal file
13
PyconTW/simple_hashlib.py
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import hashlib
|
||||||
|
|
||||||
|
|
||||||
|
def checkio(hashed_string, algorithm):
|
||||||
|
m = hashlib.new(algorithm)
|
||||||
|
m.update(hashed_string.encode('utf-8'))
|
||||||
|
return m.hexdigest()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
assert checkio('welcome', 'md5') == '40be4e59b9a2a2b5dffb918c0e86b3d7'
|
||||||
|
assert checkio('happy spam', 'sha224') == '6e9dc3e01d57f1598c2b40ce59fc3527e698c77b15d0840ae96a8b5e'
|
22
PyconTW/weekend-counter.py
Normal file
22
PyconTW/weekend-counter.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
from datetime import date, timedelta
|
||||||
|
|
||||||
|
|
||||||
|
def checkio(from_date: date, to_date: date) -> int:
|
||||||
|
"""
|
||||||
|
Count the days of rest
|
||||||
|
"""
|
||||||
|
plus_a_day = timedelta(days=1)
|
||||||
|
count = 0
|
||||||
|
while from_date != to_date:
|
||||||
|
if from_date.weekday() == 5 or from_date.weekday() == 6:
|
||||||
|
count += 1
|
||||||
|
from_date += plus_a_day
|
||||||
|
count += 1 if to_date.weekday() == 5 or to_date.weekday() == 6 else 0
|
||||||
|
return count
|
||||||
|
|
||||||
|
|
||||||
|
# These "asserts" using only for self-checking and not necessary for auto-testing
|
||||||
|
if __name__ == '__main__':
|
||||||
|
assert checkio(date(2013, 9, 18), date(2013, 9, 23)) == 2, "1st example"
|
||||||
|
assert checkio(date(2013, 1, 1), date(2013, 2, 1)) == 8, "2nd example"
|
||||||
|
assert checkio(date(2013, 2, 2), date(2013, 2, 3)) == 2, "3rd example"
|
Loading…
Reference in New Issue
Block a user