✨ 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