7155
Комментарий:
|
8372
|
Удаления помечены так. | Добавления помечены так. |
Строка 188: | Строка 188: |
== Нечто про математику == | == (не успеем!) Нечто про математику == |
Строка 194: | Строка 194: |
== Коротко про ввод и вывод в Д/З == * `ptint()` * `input()` * `int(input())` * `eval(input())`, что такое `eval()` и как работает |
|
Строка 197: | Строка 202: |
'''TODO''' 1. Условные операторы и выражения 1. Циклы 1. Моржи 1. Непустота 1. Математика |
'''TODO''': тесты для задач пока не оформлены, в TG будет отдельное сообщение, когда закончу (срок сдачи подвину соответственно) -- FrBrGeorge <<DateTime(2020-09-15T12:45:59+0300)>> 1. Ввести три числа: `a`, `b` и `c`, вывести решение уравнения $$ax^2+bx+c=0$$. При $$a\ne 0$$ это уравнение превращается в квадратное. Если решений нет, вывести `NO`, если их бесконечно много — `INF`. 1. Натуральные числа вводятся по одному в строке (конец ввода — 0), вывести ''второй максимум'' последовательности (число, строго меньшее максимума последовательности, и не меньшее остальных чисел в ней), и `NO`, если такового нет. Пользоваться последовательностями Python в этой задаче нельзя. 1. … 1. …ещё две задачи |
Логические выражения, условные операторы и цикл
Долги за прошлый раз: кеш, треш и изоляция
Связывание и refcount:
- Как кешируются объекты? (а нужно ли это знать)
- но
- проблема изолированных пространств имён
1 >>> a = [1, 2, "QQ"]; b = [a, 4]; a[1] = b 2 >>> a 3 [1, [[...], 4], 'QQ'] 4 >>> b 5 [[1, [...], 'QQ'], 4] 6 >>> a[1] is b 7 True 8 >>> b[0] is a 9 True 10 >>> c = a, b 11 >>> sys.getrefcount(a) 12 4 13 >>> sys.getrefcount(c[0]) 14 4 15 >>> del a, b 16 >>> sys.getrefcount(c[0]) 17 3 18 >>> sys.getrefcount(c[1]) 19 3 20 >>> del c
Нечто про gc
Как посмотреть все ссылки на объект: gc.get_referrers()
Алгебра логики
Операции сравнения, тип bool, True и False
Алгебра логики над bool
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
Python3: and, or, not; низкий приоритет
- Пустые и непустые объекты Python3
- Алгебра логики над произвольными объектами Python3
- OR: если A истинно, результат истинен, вычислять B не надо
- ⇒ Python: если A истинно, результат равен A, иначе B
- AND: если A ложно, результат ложен, вычислять B не надо
- ⇒ Python: если A ложно, результат равен A, иначе B
⇒ частичное вычисление выражений A и B (например, 3+3 or 100/0)
or
and
A
B
A or B
A
B
A and B
Пусто
Пусто
B
Пусто
Пусто
A
Пусто
Непусто
B
Пусто
Непусто
A
Непусто
Пусто
A
Непусто
Пусто
B
Непусто
Непусто
A
Непусто
Непусто
B
- OR: если A истинно, результат истинен, вычислять B не надо
Сравнения
Простые: == , <, !=, >= и т. п.
is , in
- Многоместные
- Таким образом,
wait шhат?
Условные действия
Конструкция a and b or c как замена тернарной операции a ? b : c в Си
Не работает, как ожидается, если b пусто
Условная операция выражение-True if выражение-условие else выражение-false
Условный оператор: if, if / else, if [/ elif [/ elif ... [else]...]]
Цикл while
- Каноническая схема цикла:
- например
break, continue
Клауза else — не выполняется, если выход из цикла был по break:
Нечто про моржа
Операция (а не выделенный оператор) связывания: «:=», см pep-0572
- основное применение (здравствуй, Си!):
- Но не только!
(не успеем!) Нечто про математику
import math vs. from math import *
вычисления в рациональных числах с помощью decimal и fractions
decimal.Decimal(1.1) vs. decimal.Decimal("1.1")
fractions.Fraction(1/3) vs. fractions.Fraction(1,3)
Коротко про ввод и вывод в Д/З
ptint()
input()
int(input())
eval(input()), что такое eval() и как работает
Д/З
Прочитать и прощёлкать учебник (до функций)
TODO: тесты для задач пока не оформлены, в TG будет отдельное сообщение, когда закончу (срок сдачи подвину соответственно) -- FrBrGeorge 2020-09-15 12:45:59
Ввести три числа: a, b и c, вывести решение уравнения $$ax^2+bx+c=0$$. При $$a\ne 0$$ это уравнение превращается в квадратное. Если решений нет, вывести NO, если их бесконечно много — INF.
Натуральные числа вводятся по одному в строке (конец ввода — 0), вывести второй максимум последовательности (число, строго меньшее максимума последовательности, и не меньшее остальных чисел в ней), и NO, если такового нет. Пользоваться последовательностями Python в этой задаче нельзя.
- …
- …ещё две задачи