/md Генератор списков Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Большинство задач этой главы ориентировано на отработку навыков по разработке функций. Ваше решение будет использоваться как библиотека. Напишите функцию make_list, которая создаёт, заполняет и возвращает список заданного размера. Параметры функции: length — требуемая длина списка; value — значение элементов списка (по-умолчанию 0). Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод result = make_list(3) result = [0, 0, 0] Пример 2 Ввод Вывод result = make_list(5, 1) result = [1, 1, 1, 1, 1] 1 /md Генератор матриц Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Напишите функцию make_matrix, которая создаёт, заполняет и возвращает матрицу заданного размера. Параметры функции: size — кортеж (ширина, высота) или одно число (для создания квадратной матрицы); value — значение элементов списка (по-умолчанию 0). Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод result = make_matrix(3) result = [ [0, 0, 0], [0, 0, 0], [0, 0, 0] ] Пример 2 Ввод Вывод result = make_matrix((4, 2), 1) result = [ [1, 1, 1, 1], [1, 1, 1, 1] ] 1 /md Функциональный нод 2.0 Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Напишите функцию gcd, которая вычисляет наибольший общий делитель последовательности чисел. Параметрами функции выступают натуральные числа в произвольном количестве, но не менее одного. Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод result = gcd(3) result = 3 Пример 2 Ввод Вывод result = gcd(36, 48, 156, 100500) result = 12 1 /md Имя of the month 2.0 Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Разработайте функцию month, которая возвращает название заданного месяца с заглавной буквы. Функция должна принимать номер месяца и дополнительно обозначение языка (по умолчанию "ru"). Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод result = month(1, "en") result = 'January' Пример 2 Ввод Вывод result = month(7) result = 'Июль' 1 /md Подготовка данных Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Напишите функцию to_string, которая формирует из последовательности данных строку. Функция должна принимать: неопределённое количество данных; необязательный параметр sep (по умолчанию пробел); необязательный параметр end (по умолчанию \n). Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод result = to_string(1, 2, 3) result = '1 2 3\n' Пример 2 Ввод Вывод data = [7, 3, 1, "hello", (1, 2, 3)] result = to_string(*data, sep=", ", end="!") result = '7, 3, 1, hello, (1, 2, 3)!' -1 /md Кофейня Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Руководство местной кофейни для программистов под названием Java-0x00 решило модернизировать систему заказа кофе. Для этого им требуется реализовать функцию order, которая принимает список предпочтений посетителя в порядке «убывания желания». Согласно положению, каждый напиток в кофейне строго определён рецептом: Эспрессо готовится из: 1 порции кофейных зерен. Капучино готовится из: 1 порции кофейных зерен и 3 порций молока. Макиато готовится из: 2 порций кофейных зерен и 1 порции молока. Кофе по-венски готовится из: 1 порции кофейных зерен и 2 порций взбитых сливок. Латте Макиато готовится из: 1 порции кофейных зерен, 2 порций молока и 1 порции взбитых сливок. Кон Панна готовится из: 1 порции кофейных зерен и 1 порции взбитых сливок. В глобальной переменной in_stock содержится словарь, описывающий ингредиенты в наличии. Ключи словаря: coffee, cream, milk. Функция должна вернуть: название напитка, который будет приготовлен; сообщение «К сожалению, не можем предложить Вам напиток», если ни одно из предпочтений не может быть приготовлено. Если заказ, может быть совершён, количество доступных ингредиентов должно соответствующим образом уменьшиться. Примечание В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод in_stock = {"coffee": 1, "milk": 2, "cream": 3} print(order("Эспрессо", "Капучино", "Макиато", "Кофе по-венски", "Латте Макиато", "Кон Панна")) print(order("Эспрессо", "Капучино", "Макиато", "Кофе по-венски", "Латте Макиато", "Кон Панна")) Эспрессо К сожалению, не можем предложить Вам напиток Пример 2 Ввод Вывод in_stock = {"coffee": 4, "milk": 4, "cream": 0} print(order("Капучино", "Макиато", "Эспрессо")) print(order("Капучино", "Макиато", "Эспрессо")) print(order("Капучино", "Макиато", "Эспрессо")) Капучино Макиато Эспрессо 3 4 /md В эфире рубрика «Эксперименты» Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Лаборанты проводят эксперимент и запросили разработку системы обработки данных. Результатами эксперимента должны стать пары рациональных чисел. Для работы им требуются функции: enter_results(first, second, ...) — добавление данных одного или нескольких результатов (гарантируется, что количество параметров будет чётным); get_sum() — возвращает пару сумм результатов экспериментов; get_average() — возвращает пару средних арифметических значений результатов экспериментов. Все вычисления производятся с точностью до сотых. Примечание В решении не должно быть вызовов требуемых функций. Пример 1 Ввод Вывод enter_results(1, 2, 3, 4, 5, 6) print(get_sum(), get_average()) enter_results(1, 2) print(get_sum(), get_average()) (9, 12) (3.0, 4.0) (10, 14) (2.5, 3.5) Пример 2 Ввод Вывод enter_results(3.5, 2.14, 45.2, 37.99) print(get_sum(), get_average()) enter_results(5.2, 7.3) print(get_sum(), get_average()) enter_results(1.23, 4.56, 3.14, 2.71, 0, 0) print(get_sum(), get_average()) (48.7, 40.13) (24.35, 20.07) (53.9, 47.43) (17.97, 15.81) (58.27, 54.7) (9.71, 9.12) 4 6 /md Длинная сортировка Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Напишите lambda выражение для сортировки списка слов сначала по длине, а затем по алфавиту без учёта регистра. Примечание В решении не должно быть ничего, кроме выражения. Пример 1 Ввод Вывод string = 'мама мыла раму' print(sorted(string.split(), key=<ваше выражение>)) ['мама', 'мыла', 'раму'] Пример 2 Ввод Вывод string = 'Яндекс использует Python во многих проектах' print(sorted(string.split(), key=<ваше выражение>)) ['во', 'Python', 'многих', 'Яндекс', 'проектах', 'использует'] -1 /md Чётная фильтрация Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Напишите lambda выражение для фильтрации чисел с чётной суммой цифр. Примечание В решении не должно быть ничего, кроме выражения. Пример 1 Ввод Вывод print(*filter(<ваше выражение>, (1, 2, 3, 4, 5))) 2 4 Пример 2 Ввод Вывод print(*filter(<ваше выражение>, (32, 64, 128, 256, 512))) 64 512 1 /md Ключевой секрет Ограничение времени 1 секунда Ограничение памяти 64.0 Мб Ввод стандартный ввод Вывод стандартный вывод Вася любит секреты и шифрование. Он часто пользуется шифром на основе замен и просит разработать вас функцию, которая позволит ему быстро шифровать сообщения. Напишите функцию secret_replace(text, **replaces), которая принимает: текст требующий шифрования; именованные аргументы — правила замен, представляющие собой кортежи из одного или нескольких значений. Функция должна вернуть зашифрованный текст. Примечание Ваше решение должно содержать только функции. В решении не должно быть вызовов требуемых функций. Обратите внимание, что позиционный аргумент требуемой функции не должен иметь однобуквенного имени. Для понимания ошибки исследуйте следующих код: def func(a, **b): ... func(1, **{'a': 2}) Пример 1 Ввод Вывод result = secret_replace("Hello, world!", l=("hi", "y"), o=("123", "z")) result = 'Hehiy123, wzrhid!' Пример 2 Ввод Вывод result = secret_replace( "ABRA-KADABRA", A=("Z", "1", "!"), B=("3",), R=("X", "7"), K=("G", "H"), D=("0", "2"), ) result = 'Z3X1-G!0Z371' -1 /py def make_list(length, value=0): return [value] * length /py def make_matrix(size, value=0): if type(size) is int: return [[value] * size for _ in range(size)] else: return [[value] * size[0] for _ in range(size[1])] /py def gcd(*nums): nums = list(nums) for i in range(len(nums) - 1): a, b = nums[i], nums[i + 1] while a != b: if a > b: a -= b else: b -= a nums[i + 1] = a return nums[-1] /py def month(num, lang="ru"): mths = ( ("January", "Январь"), ("February", "Февраль"), ("March", "Март"), ("April", "Апрель"), ("May", "Май"), ("June", "Июнь"), ("July", "Июль"), ("August", "Август"), ("September", "Сентябрь"), ("October", "Октябрь"), ("November", "Ноябрь"), ("December", "Декабрь") ) if lang == "en": return mths[num - 1][0] else: return mths[num - 1][1] /py def to_string(*nums, sep=" ", end="\n"): res = '' for i in range(len(nums)): res += str(nums[i]) if i != len(nums) - 1: res += sep return res + end /py def order(*names): global in_stock res = "" message = "К сожалению, не можем предложить Вам напиток" d = { "Эспрессо": {"coffee": 1}, "Капучино": {"coffee": 1, "milk": 3}, "Макиато": {"coffee": 2, "milk": 1}, "Кофе по-венски": {"coffee": 1, "cream": 2}, "Латте Макиато": {"coffee": 1, "milk": 2, "cream": 1}, "Кон Панна": {"coffee": 1, "cream": 1} } for cof in names: f = True for k in d[cof].keys(): if d[cof][k] > in_stock[k]: f = False if f: for k in d[cof].keys(): in_stock[k] -= d[cof][k] message = cof break return message /py def enter_results(*enter, nums=[]): nums += list(enter) return nums def get_sum(): sum1, sum2 = 0, 0 for n in enter_results()[::2]: sum1 += n for n in enter_results()[1::2]: sum2 += n return sum1, sum2 def get_average(): sum1, l1, sum2, l2 = 0, 0, 0, 0 for n in enter_results()[::2]: sum1 += n l1 += 1 for n in enter_results()[1::2]: sum2 += n l2 += 1 return sum1 / l1, sum2 / l2 /py lambda word: (len(word), word.lower()) /py lambda num: sum(map(int, str(num))) % 2 == 0 /py def secret_replace(text, **replaces): counter = {k: 0 for k in replaces.keys()} while True: f = False for k in replaces.keys(): if k in text: text = text.replace(k, replaces[k][counter[k]], 1) if counter[k] >= len(replaces[k]) - 1: counter[k] = -1 counter[k] += 1 f = True if not f: break return text