25092
Pythonist.ru - помощь в подготовке к собеседованию на позицию Python Developer. Реклама: @anothertechrock РКН: https://rknn.link/car
Задача с кодом. Расстояние между точками
Напишите функцию, которая будет принимать координаты двух точек (в двумерной декартовой системе координат) и возвращать расстояние между этими точками.
Координаты будут передаваться в функцию в виде строки из четырех чисел через запятую:"x1,y1,x2,y2", где x1,y1 — координаты первой точки, а x2,y2 — координаты второй.
Примечание: если расстояние окажется числом с плавающей запятой, его нужно округлить до сотых (например, 2.34).
Примеры:
shortestDistance("1,1,2,1") ➞ 1
shortestDistance("1,1,3,1") ➞ 2
shortestDistance("-5,1,3,1") ➞ 8
shortestDistance("-5,2,3,1") ➞ 8.06
Решение на нашем сайте.
@pythonknigiru - тут можете скачать книги на русском языке.
Читать полностью…
ООП. Как писать модульные тесты для методов экземпляра в Python
Давайте разберем, как настроить модульные тесты для экземпляров классов. Мы напишем тесты для проверки функциональности класса Book. Он имеет такие атрибуты, как title, author, pages, price, discount.
#ооп #тесты
🐞QaRocks — всё о тестировании ПО
Что у нас есть:
— уникальные переводы англоязычных туториалов
— полный QA Учебник роадмап, как и что учить новичку.
— еженедельные дайджесты с новостями и туториалами
— тесты, которые должен пройти каждый тестировщик
— подборки QA книг
— регулярные холиварные обсуждения — вот, например, подписчики рассказывают, какие курсы проходили перед началом работы;
Также у нас Чат с вакансиями, где уже более 100 работодателей постят каждый день свои вакансии по QA
Подписывайся на QaRocks и узнай уже наконец разницу между тест-планом и баг-репортом 😇
Задача с кодом. Переворот
Число 6090609 имеет особенность: если его перевернуть вверх ногами (т. е. развернуть на 180 градусов), вы получите то же самое число — 6090609
Напишите функцию, которая будет принимать строку из цифр 0, 6, 9 и определять, будет ли образованное ими число после переворота тем же самым числом.
Примеры:
same_upsidedown("6090609") ➞ True
same_upsidedown("9669") ➞ False
# При перевороте превращается в 6996
same_upsidedown("69069069") ➞ True
Решение на нашем сайте.
Тест. Множества (уровень — средний)
Множество в Python — «контейнер», содержащий не повторяющиеся элементы в случайном порядке.
Хорошо ли вы умеете пользоваться множествами? Пройдите тест из 10 вопросов и проверьте!
#тест
Задача на логику. Разработчицы из компании «ThreeWayLand»
Вы — в IT-компании «ThreeWayLand». Здесь, как вам известно, фронтендеры всегда говорят правду, бэкендеры всегда лгут, а менеджеры — по настроению.
Возле кофемашины вы встречаете трех девушек. Среди них точно есть фронтендер, бэкендер и менеджер, но кто есть кто вы не знаете, а узнать бы хотелось.
Пока пьете кофе, можно успеть задать два вопроса, на которые девушки смогут ответить «да» или «нет». (Вопросы можно задавать как любой из девушек, так и всем трем одновременно, отвечать они тогда будут по очереди. Но вопросов у вас только два).
Что можно спросить, чтобы точно определить специализацию всех трех?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Задача с кодом. Сложное упорядочивание
Упорядочивание слов в ступенчатом лексикографическом порядке происходит так:
1. Сперва слова упорядочиваются по длине
2. Затем слова одного размера упорядочиваются в словарном порядке (по алфавиту).
Например:
- «tray» < «trapped», потому что «tray» имеет длину 4, а «trapped» - 7
- «trap» < «tray», потому что у обоих слов длина 4, но «trap» идет перед «tray» в словаре.
Задание:
Напишите функцию, которая будет принимать список слов и возвращать список, где они будут упорядочены в ступенчатом лексикографическом порядке.
Примеры:
make_grlex(["small", "big"])Решение на нашем сайте.
➞ ["big", "small"]
make_grlex(["cat", "ran", "for", "the", "rat"])
➞ ["cat", "for", "ran", "rat", "the"]
make_grlex(["this", "is", "a", "small", "test"])
➞ ["a", "is", "test", "this", "small"]
Задача с кодом. Самое длинное слово
Напишите функцию, которая будет находить самое длинное слово в предложении.
Если будет найдено два и больше слов одинаковой длины, нужно вернуть первое из них.
Небуквенные символы (апостроф, точка, запятая и т. п.) считаются частью слова, к которому прилегают.
Примеры
longest_word("Margaret's toy is a pretty doll.")
➞ "Margaret's"
longest_word("A thing of beauty is a joy forever.")
➞ "forever."
longest_word("Forgetfulness is by all means powerless!")
➞ "Forgetfulness"
Решение на нашем сайте.
Ответ к предыдущей задаче для новичков
# calculate_even_sum.py
def calculate_even_sum(numbers):# test_calculate_even_sum.py
return sum(num for num in numbers if num % 2 == 0)
import pytest
from calculate_even_sum import calculate_even_sum
def test_positive_numbers():
assert calculate_even_sum([1, 2, 3, 4, 5]) == 6
assert calculate_even_sum([10, 20, 30, 40, 50]) == 150
def test_negative_numbers():
assert calculate_even_sum([-1, -2, -3, -4, -5]) == -6
assert calculate_even_sum([-10, -20, -30, -40, -50]) == -150
def test_mixed_numbers():
assert calculate_even_sum([-5, 10, -3, 8, 2]) == 20
assert calculate_even_sum([0, 0, 0, 0, 0]) == 0
def test_empty_list():
assert calculate_even_sum([]) == 0
def test_no_even_numbers():
assert calculate_even_sum([1, 3, 5, 7, 9]) == 0
В этом примере функция calculate_even_sum() принимает список целых чисел и возвращает сумму только четных чисел, проверяя для этого элементы списка на четность.Тесты проверяют правильность работы функции для различных входных данных.
Основы. Как писать модульные тесты на Python
Юнит-тестирование — это техника тестирования программного обеспечения (ПО), при которой отдельные компоненты или блоки приложения тестируются независимо от остальной части приложения. Python обеспечивает встроенную поддержку юнит-тестирования с помощью фреймворка unittest.
#основы
Задача на логику. Какие числа поставите вместо вопросительных знаков и почему?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Тест. Условия Python
Условия — очень частые конструкции в Python. Практически любая программа представляет собой разные наборы действий, которые нужно выполнить при соблюдении тех или иных условий.
Проверьте, насколько хорошо вам удается работа с условиями: пройдите тест из 10 вопросов!
#тест
Tips & Tricks. Как перевернуть строку в Python
Разбираем три способа перевернуть строку: с помощью рекурсии, с помощью среза и с помощью встроенных методов Python.
#tipsandtricks #строки
Строки. Как обрезать строку в Python
В этой статье мы рассмотрим несколько способов обрезки строк. Будем применять срезы, строковый метод rsplit(), форматирование и метод shorten() из модуля textwrap.
#строки
Функции. Рекурсивный метод нахождения чисел Фибоначчи
Пишем программу, принимающую число членов последовательности Фибоначчи и при помощи рекурсии вычисляющую все числа, входящие в эту последовательность.
#функции #рекурсия
Тест. Модуль random в Python
Модуль random в Python предоставляет функции для генерации случайных чисел, букв, случайного выбора элементов последовательности. Проверьте, насколько хорошо вы умеете применять все это на практике — пройдите тест!
#тест
Задача на логику. Фокус с пятью картами
Фокусник берет колоду из 52 карт и отдает ее зрителям. Зрители выбирают (каким угодно способом) любые 5 карт и отдают их помощнику фокусника. Тот смотрит на карты и называет фокуснику 4 из них. В ответ фокусник называет пятую.
Кроме мастей и значений карт, фокусник вроде бы не получает никакой дополнительной информации (помощник говорит ровным голосом, без пауз и т.д.).
Каким образом фокуснику удается "угадать" пятую карту?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Tips & Tricks. Забудьте об использовании print() для отладки в Python
Пожалуй, большинство разработчиков для вывода данных в консоль при отладке используют функцию print() . В этой статье мы рассказываем о библиотеке Ice Cream и функции ic(), которые существенно упрощают и ускоряют процесс дебаггинга.
#tipsandtricks #модули
Топ. Как вручную установить пакет в Python
Большинство пакетов в Python сейчас спроектированы так, чтобы быть совместимыми с менеджером пакетов pip. Но что если у вас есть пакеты, несовместимые с pip, и вам нужно установить пакет вручную? Сегодня мы разберем, как это делается.
#топ
Основы. Как исправить ошибку «’builtin_function_or_method’ object is not subscriptable» в Python
Функции Python — это вызываемые объекты. Это означает, что для выполнения кода, определенного в функции, мы можем вызвать ее, поставив круглые скобки после имени функции. А вот использование квадратных скобок вместо круглых приводит к ошибке.
#основы #функции
Tips & Tricks. Как удалить None из списка в Python
Исключение значений None из списка может понадобиться, например, в предварительной обработке данных для машинного обучения. Давайте посмотрим, как это делается.
#tipsandtricks #списки
Задача на логику. Пилюли
У вас есть две баночки с пилюлями, маркированные "А" и "В". В день вам нужно съесть по одной пилюле из каждой баночки, если же вы съедите больше одной пилюли, то умрете.
Однажды вы взяли одну пилюлю из баночки "А", а когда стали вытряхивать пилюлю из банки "В", случайно выпало две штуки. Теперь у вас на ладони лежат три пилюли, совершенно неразличимые по внешнему виду. Как с наименьшими потерями выйти из этой ситуации?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Модули. Как получить текущую директорию в Python
Многие программы на Python нуждаются в навигации по файловой системе для чтения и записи файлов. При этом частой операцией является получение текущего каталога.
#модули #основы
Задача для новичков
Напишите функцию calculate_even_sum(), которая принимает на вход список чисел и возвращает сумму всех четных чисел в этом списке.
Напишите также тесты с использованием pytest, чтобы проверить правильность работы функции на разных входных данных.
Свои варианты пишите в комментариях! Решение - сегодня вечером.
#задача #coding
🚀 Отправляемся в мир Django: ваш первый проект в веб-разработке
22 июля в 19:00 мск — не пропустите открытый урок
Что ждет вас на вебинаре:
- основы Django: краткий обзор архитектуры, установка и создание нового проекта;
- ваше первое приложение: определение и регистрация простой модели данных, создание представления и маршрута для отображения информации на странице;
- работа с шаблонами: использование шаблонов для отображения данных в браузере.
Спикер — опытный системный инженер, веб-разработчик и преподаватель.
Встречаемся в преддверии старта курса «Специализация Python Developer». Все участники вебинара получат специальную цену на обучение.
🔴 Регистрируйтесь прямо сейчас, чтобы не пропустить бесплатный урок: https://vk.cc/cytNIoРеклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Задача с кодом. Цифровое расстояние
Напишите функцию, которая будет принимать два целых числа, вычислять модуль их разности и выводить сумму цифр полученного числа. Пример:
digit_distance(234, 489) ➞ 12Примечания:
# |2 - 4| + |3 - 8| + |4 - 9| = 2 + 5 + 5 = 12
digit_distance(121, 599) ➞ 19Решение на нашем сайте.
digit_distance(12, 12) ➞ 0
digit_distance(10, 20) ➞ 1
Задача на логику. С кем поехать?
Каспер, Стефан и Януш предложили подвезти вас до дома. Двое из них хотят вас убить. Один — нет. Вам нужно выбрать, с кем поехать (естественно, вы хотите добраться домой живым).
Все трое сделали следующие заявления:
Каспер: Стефан и Януш говорят правду.
Стефан: Если хочешь жить, выбери Каспера или Януша.
Януш: Если хочешь жить, не выбирай Стефана.
Вам известно, что как минимум один из этой троицы всегда врет (и это никак не связано с тем, хочет ли этот человек вас убить).
Кого из троих нужно выбрать?
Решение тут. Просьба потратить хотя бы 10 минут перед тем как читать решение.
#логическаязадача
Задача с кодом. ABACABADABACABA
Напишите функцию, которая будет принимать буквы английского алфавита и возвращать строки, придерживаясь шаблона «ABACABADABACABA».
Суть шаблона в следующем. Все начинается с первой буквы (А). Каждая следующая буква добавляется в центр, а предыдущий паттерн располагается по бокам от нее. Например:
A ➞ **A**Примеры
B ➞ A**B**A
C ➞ ABA**C**ABA
D ➞ ABACABA**D**ABACABA
E ➞ ABACABADABACABA**E**ABACABADABACABA
F ➞ ABACABADABACABAEABACABADABACABA**F**ABACABADABACABAEABACABADABACABA
И так далее
ABA("A") ➞ "A"
ABA("B") ➞ "ABA"
ABA("E") ➞ "ABACABADABACABAEABACABADABACABA"
Решение на нашем сайте.
Ответ к предыдущей задаче для новичков
# is_palindrome.py
def is_palindrome(number):# test_is_palindrome.py
number_str = str(number)
return number_str == number_str[::-1]
import pytest
from palindrome import is_palindrome
def test_positive_palindrome():
assert is_palindrome(121) == True
assert is_palindrome(1221) == True
def test_negative_palindrome():
assert is_palindrome(123) == False
assert is_palindrome(12321) == False
def test_single_digit():
assert is_palindrome(9) == True
def test_negative_number():
assert is_palindrome(-121) == False
def test_large_palindrome():
assert is_palindrome(12345678987654321) == True
def test_empty_input():
with pytest.raises(ValueError):
is_palindrome('')
def test_string_input():
with pytest.raises(ValueError):
is_palindrome('hello')
def test_float_input():
with pytest.raises(ValueError):
is_palindrome(12.21)
В этом примере функция is_palindrom() принимает число, преобразует его в строку и далее сравнивает эту строку с этой же строкой, но записанной в обратном порядке. Если они равны, возвращается True, в противном случае False. Тесты проверяют правильность работы функции для различных входных данных.