⚡️ Цепочка обязанностей (Chain of Responsibility)
Это паттерн, который позволяет передавать запрос по цепочке обработчиков. Обработчики могут в любой момент прервать передачу запроса.
Также, таким образом мы можем избавится от большого количества if-ов в одном файле и перенести их в отдельные классы.
Возьмём, к примеру, обработку доступа к файлу. Первым делом вы проверяете, авторизован ли пользователь, после является ли он админом. И если вас попросят добавить ещё проверку, сделать это будет намного проще.
#паттерны #CoR
Это паттерн, который позволяет передавать запрос по цепочке обработчиков. Обработчики могут в любой момент прервать передачу запроса.
Также, таким образом мы можем избавится от большого количества if-ов в одном файле и перенести их в отдельные классы.
Возьмём, к примеру, обработку доступа к файлу. Первым делом вы проверяете, авторизован ли пользователь, после является ли он админом. И если вас попросят добавить ещё проверку, сделать это будет намного проще.
#паттерны #CoR
⚡️ Задачка с собеседования | #Easy
Условие:
Вам нужно написать простенькую программу для обработки кода. Она работает так, если команда:
· 'i', то мы добавляем к числу 1 (которое изначально 0)
· 'd', то мы забираем у числа единицу
· 's', то мы возводим значение в квадрат
· 'o', то мы добавляем число в массив, который после возвращаем
Если вам встречаются другие символы, просто игнорируйте их.
Пример:
parse('ooo') ➞ [0, 0, 0]
parse('iiisdoso') ➞ [8, 64]
parse('isoisoiso') ➞ [1, 4, 25]
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
Условие:
Вам нужно написать простенькую программу для обработки кода. Она работает так, если команда:
· 'i', то мы добавляем к числу 1 (которое изначально 0)
· 'd', то мы забираем у числа единицу
· 's', то мы возводим значение в квадрат
· 'o', то мы добавляем число в массив, который после возвращаем
Если вам встречаются другие символы, просто игнорируйте их.
Пример:
parse('ooo') ➞ [0, 0, 0]
parse('iiisdoso') ➞ [8, 64]
parse('isoisoiso') ➞ [1, 4, 25]
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
⚡️ Погадаем?
aztro — проект, предоставляющий информацию о гороскопе и астрологии в режиме реального времени через HTTP API. А PyAztro — интерфейс для взаимодействия с ним.
Установка:
Вы можете получить доступ к гороскопу на этот день, предыдущий (yesterday) или завтрашний (tomorrow). Подробнее в документации.
P.S. На фото выше гороскоп на сегодня для Овен. Файл с кодом будет в комментариях.
aztro — проект, предоставляющий информацию о гороскопе и астрологии в режиме реального времени через HTTP API. А PyAztro — интерфейс для взаимодействия с ним.
Установка:
pip install pyaztro
Вы составляете запрос, передавая знак зодиака, после получаете класс с совместимостью, счастливым числом, цветом, временем и всем, что есть в гороскопах. Вы можете получить доступ к гороскопу на этот день, предыдущий (yesterday) или завтрашний (tomorrow). Подробнее в документации.
P.S. На фото выше гороскоп на сегодня для Овен. Файл с кодом будет в комментариях.
⚡️ Поиск в ширину
Тут про DFS. А в этот раз поговорим про breadth-first Search — алгоритм, способный быстро и без ограничений пройтись по графу.
Алгоритм: Сначала берём стартовую вершину и добавляем в очередь. После вытаскиваем её из очереди и добавляем соседей. С соседями делаем тоже самое, что и с первой вершиной.
BFS часто используют для вычисления расстояния между вершинами, поиска кратчайшего пути.
#алгоритмы #графы
Тут про DFS. А в этот раз поговорим про breadth-first Search — алгоритм, способный быстро и без ограничений пройтись по графу.
Алгоритм: Сначала берём стартовую вершину и добавляем в очередь. После вытаскиваем её из очереди и добавляем соседей. С соседями делаем тоже самое, что и с первой вершиной.
BFS часто используют для вычисления расстояния между вершинами, поиска кратчайшего пути.
#алгоритмы #графы
⚡️ Задачка с собеседования | #Medium
Условие:
Напишите функцию, которая принимает список чисел и переносит все нули в его конец. Функция не должна ничего возвращать, она только меняет существующий массив.
Придумайте решение без append, pop и remove, это довольно медленные операции.
Пример:
move_zeros([1, 0, 0]) ➞ [1, 0, 0]
move_zeros([1, 0, 5]) ➞ [1, 5, 0]
move_zeros([0, 0, 1]) ➞ [1, 0, 0]
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
Условие:
Напишите функцию, которая принимает список чисел и переносит все нули в его конец. Функция не должна ничего возвращать, она только меняет существующий массив.
Придумайте решение без append, pop и remove, это довольно медленные операции.
Пример:
move_zeros([1, 0, 0]) ➞ [1, 0, 0]
move_zeros([1, 0, 5]) ➞ [1, 5, 0]
move_zeros([0, 0, 1]) ➞ [1, 0, 0]
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
⚡️ Фишка срезов
С помощью срезов мы можем не просто получать определённое количество элементов, а и менять их. Называют это так: «Изменение путем присваивания».
Таким образом мы заменяем элементы внутри этого среза другими из итератора (список, кортёж, словарь, range).
С их помощью мы также можем добавлять/удалять элементы, опустошать список и многое другое. Но в разреженных срезах такое не работает.
#теория
С помощью срезов мы можем не просто получать определённое количество элементов, а и менять их. Называют это так: «Изменение путем присваивания».
Таким образом мы заменяем элементы внутри этого среза другими из итератора (список, кортёж, словарь, range).
С их помощью мы также можем добавлять/удалять элементы, опустошать список и многое другое. Но в разреженных срезах такое не работает.
#теория
⚡️ Парсим XML и HTML
И самым лучшим выбором для этого является lxml. Это библиотека позволяет быстро обрабатывать файлы XML и HTML формата.
Установка:
Единственным недостатком модуля является его сильная зависимость от C. Подробнее обо всём на GitHub.
#миниурок #lxml
И самым лучшим выбором для этого является lxml. Это библиотека позволяет быстро обрабатывать файлы XML и HTML формата.
Установка:
pip install lxml
Он намного быстрее, чем html.parser и с ним в разы проще работать. Более стабильной и удобной альтернативой является html5lib, но это довольно медленная библиотека.Единственным недостатком модуля является его сильная зависимость от C. Подробнее обо всём на GitHub.
#миниурок #lxml
⚡️ Задачка с собеседования | #Medium
Условие:
Вам нужно найти в промежутке от a до b (range(a, b + 1)) числа с особым свойством. Это те, у которых сумма их цифр, возведенных в степень их позиции равняется тому же числу.
Примеры:
sum_dig_pow(1, 100) ➞ [1, 2, 3, 4, 5, 6, 7, 8, 9, 89]
sum_dig_pow(100, 135) ➞ [135]
sum_dig_pow(90, 100) ➞ []
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
Условие:
Вам нужно найти в промежутке от a до b (range(a, b + 1)) числа с особым свойством. Это те, у которых сумма их цифр, возведенных в степень их позиции равняется тому же числу.
Примеры:
sum_dig_pow(1, 100) ➞ [1, 2, 3, 4, 5, 6, 7, 8, 9, 89]
sum_dig_pow(100, 135) ➞ [135]
sum_dig_pow(90, 100) ➞ []
📌 Пишите ваше решение в комментариях. Решение будет через несколько часов на этом канале. 👇
#Задачка_с_собеседования
⚡️ Создаём игру
С помощью arcade мы можем создавать полноценные игры с 2D графикой.
Установка:
Конечно, есть и недостатки: вам придётся вручную управлять окном и его рендером, а также циклом обработки действий.
У модуля очень хорошая документация, поэтому проблем с его изучением возникнуть не должно.
#миниурок #arcade
С помощью arcade мы можем создавать полноценные игры с 2D графикой.
Установка:
pip install arcade
Модуль может отрисовывать спрайты, анимировать их, работать с клавиатурой и со звуками. Но у него реализованы и более сложные системы, такие как физика и система частиц.Конечно, есть и недостатки: вам придётся вручную управлять окном и его рендером, а также циклом обработки действий.
У модуля очень хорошая документация, поэтому проблем с его изучением возникнуть не должно.
#миниурок #arcade