Логические выражения и цикл
Разбор задачи «Неравенство треугольника»
С вложенным if
- С вычислением максимума
Кстати, о максимуме из трёх:
1 M = M if (M := a if a > b else b) > c else c
Логические выражения
Вложенные условия → операция and
Любое условие из двух → or
Отрицание условия → not
or |
|
and |
||||
A |
B |
A or B |
|
A |
B |
A and B |
False |
False |
False |
|
False |
False |
False |
False |
True |
True |
|
False |
True |
False |
True |
False |
True |
|
True |
False |
False |
True |
True |
True |
|
True |
True |
True |
- Перепишем неравенство треугольника
«проверка на не-треугольник» (просто not от исходного выражения!)
правило раскрытия скобок и ǸOT (или наоборот ☺)
далее — булева алгебра (кажется, была в школе)…
вся правда о логических выражениях в Python
Цикл
Для записи алгоритма требуются (грубое предположение):
- переменные
- условные операторы
- циклы
Простой while:
- Пример: цикл со счётчиком
- Каноническая схема цикла:
- Инициализация
- Проверка условия
- Тело
- Изменение условия
- Пhимер: таблица умножения на 6
- Цикл по вводу
Поиск первого: флаговая переменная, break и else
Пропуск фрагмента кода: continue
Вложенные циклы
Принцип: внутри цикла может быть что угодно. Если там вложенный цикл. он начнётся, отработает и закончится.
- Пример: Цикл по вводу + цикл внутри
- Пример: Таблица умножения от 2 до 6
- Эффект от нарушения канонической схемы
Д/З
- Прощёлкать:
TODO
- ?
- ?
- ?