lambda - ключевое слово, позволяющее объявить лямбда-выражение (анонимную функцию)
Лямбда-выражение в Python может содержать только одну какую либо инструкцию, возвращающую значение, либо же не возвращающую.
Синтаксис -
lambda parameters: expression
например, лямбда выражение, возвращающее значение входного параметра, увеличенного на 1:
f = lambda x: x + 1
f(1) # -> 2
filter - функция, выполняющая фильтрацию последовательности
сигнатура:
def filter(func: Callable[[Any], bool], source: Iterable[Any]) -> Iterable[Any]
где func - вызываемый объект, имеющий в качестве входного параметра один любой объект и возвращающий логическое значение
source - исходный итерируемый объект
Возврат: Последовательность, составленная из всех элементов, для которых func вернёт true. Возвращаемое значение имеет тип объекта-итератора и является неиндексируемым.
пример:
a = [1, 2, 3, 4]
print(list(filter(lambda p: p > 2, a))) #распечатает [3, 4]
Для задания функции-фильтратора для передачи в filter обычно использую лямбда-выражения
map - функция, применяющая указанную функцию к каждому элементу входной последовательности.
def map(func: Callable[[Any], Any], iterable: Iterable[Any]) -> Iterable[Any]
Где:
func - функция, применяемая к каждому элементу последовательности
iterable - исходная последовательность
Возврат:
Последовательность, составленную из возвращённых значений переданной функцией для каждого из исходных элементов в порядке следования исходных элементов. Возвращаемое значение имеет тип объекта-итератора и является неиндексируемым.
Пример
list_of_str = ['1', '2', '5', '10']
print(list(map(int, list_of_str))) #[1, 2, 5, 10]
import sys - оператор, импортирующий в текущий файл модуль sys
sys.stdin - предоставляет доступ к стандартному потоку ввода для интерпретатора Python
Я тебе дал,а ты сам подумай)
Объяснение:
Repeat — это цикл с пост условием то есть в первый раз всё равно выполнится. Теперь разберём цикл, он будет выполнять это действие
(p:=p*0.1) пока (p) не станет меньше 0.1 , теперь работаем в теле цикла, (p) изначально равен двум по этому получаем p:=1*0,1; получаем p:=0,1 проверяем условие 0,1<0,1 нет повторяем второй раз цикл, теперь p:=0,1 а не 1 как было в первый раз p:=0,1*0,1 p:=0,01 проверяем условие
0,01<0,1 да меньше цикл прерывается и (p) остаётся равным 0,01