From 948f2c5176411440c96221efa365983e8719c415 Mon Sep 17 00:00:00 2001 From: DeviatovaMY Date: Fri, 10 Oct 2025 10:47:27 +0300 Subject: [PATCH] =?UTF-8?q?=D0=A2=D0=95=D0=9C=D0=903/report.md?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- TEMA3/report.md | 716 ++++++++++++++++++++++++++++++++++++++++++++++++ TEMA3/task.md | 93 +++++++ 2 files changed, 809 insertions(+) create mode 100644 TEMA3/report.md create mode 100644 TEMA3/task.md diff --git a/TEMA3/report.md b/TEMA3/report.md new file mode 100644 index 0000000..0e0403f --- /dev/null +++ b/TEMA3/report.md @@ -0,0 +1,716 @@ +# Отчет по теме 3 + +Девятова Мария, А-03-23 + +## 1 Запуск интерактивной оболочки IDLE, стандартные подготовительные операции + +## 2 Преобразование простых базовых типов объектов + +### 2.1 Преобразование в логический тип с помощью функции bool(). + +С помощью функции bool() были преобразованы объекты в логический тип. В примерах возвращает True, если передаваемое целое число не равно нулю или если передаваемая строка не является пустой. + +``` +logiz1=bool(56); logiz1; type(logiz1) +True + +logiz2=bool(0); logiz2; type(logiz2) +False + +logiz3=bool("Beta"); logiz3; type(logiz3) +True + +logiz4=bool(""); logiz4; type(logiz4) +False + +``` + +### 2.2 Преобразование в целое десятичное или вещественное число + +С помощью функции int() были преобразованы объекты в целочисленный тип данных. Вторым аргументом можно указывать систему счисления, в которой представлен объект. По умолчанию десятичная. + +``` +tt1=int(198.6); tt1; type(tt1) +198 + +tt2=int("-76"); tt2; type(tt2) +-76 + +tt3=int("B",16); tt3; type(tt3) +11 + +tt4=int("71",8); tt4; type(tt4) +57 + +tt5=int("98.76"); tt5; type(tt5) +Traceback (most recent call last): + File "", line 1, in + tt5=int("98.76"); tt5; type(tt5) +ValueError: invalid literal for int() with base 10: '98.76' +``` + +При передаче строки, в которой записано вещественное число, возникает ошибка, потому как функция принимает строку только с цифровыми символами. +Было произведено преобразование целых чисел или строк символов в вещественное число – с помощью функции float(). + +``` +flt1=float(789); flt1; type(flt1) +789.0 + +flt2=float(-6.78e2); flt2; type(flt2) +-678.0 + +flt3=float("Infinity"); flt3; type(flt3) +inf + +flt4=float("-inf"); flt4; type(flt4) +-inf + +``` + +### 2.3 Преобразование десятичных чисел в другие системы счисления. + +Было произведено преобразование десятичного числа 123 соотвественно в двоичную, восьмеричную и шестнадцатеричную системы счисления. Для проверки были проведены обратные преобразования. + +``` +hh=123 +dv1=bin(hh); dv1 +'0b1111011' +vos1=oct(hh); vos1 +'0o173' +shs1=hex(hh); shs1 +'0x7b' +int(dv1, 2) +123 +int(vos1, 8) +123 +int(shs1, 16) +123 +``` + +## 3 Преобразования более сложных базовых типов объектов + +### 3.1 Преобразование в строку символов с помощью функции str(). + +Было продемонстрировано преобразование объектов различных типов в строку. + +``` +strk1=str(23.6); strk1 +'23.6' +strk2=str(logiz3); strk2 +'True' +strk3=str(["A","B","C"]); strk3 +"['A', 'B', 'C']" +strk4=str(("A","B","C")); strk4 +"('A', 'B', 'C')" +strk5=str({"A":1,"B":2,"C":9}) +``` + +### 3.2 Преобразование элементов объекта в список с помощью функции list(). + +Были преобразованы объекты различных типов в списки. + +``` +spis1=list("Строка символов"); spis1 +['С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в'] +spis2=list((124,236,-15,908)); spis2 +[124, 236, -15, 908] +spis3=list({"A":1,"B":2,"C":9}); spis3 +['A', 'B', 'C'] +``` + +Т.к. при преобразовании словаря получается список ключей словаря, ниже представлены дополнительные инструкции для получения списка значений и списка пар "ключ - значение" + +``` +spis4=list({"A":1,"B":2,"C":9}.values()); spis4 +[1, 2, 9] +spis5=list({"A":1,"B":2,"C":9}.items()); spis5 +[('A', 1), ('B', 2), ('C', 9)] +``` + +### 3.3 Преобразование элементов объектов в кортеж с помощью функции tuple(). + +``` +kort7=tuple('Строка символов'); kort7 +('С', 'т', 'р', 'о', 'к', 'а', ' ', 'с', 'и', 'м', 'в', 'о', 'л', 'о', 'в') +kort8=tuple(spis2); kort8 +(124, 236, -15, 908) +kort9=tuple({"A":1,"B":2,"C":9}); kort9 +('A', 'B', 'C') +``` + +### 3.4 Удаление объектов + +Была очищена оперативная память от ранее созданных объектов с помощью инструкции del. Затем формально было проверено отсутствие указанных объектов. + +``` +del strk5, kort8 +dir() +['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'dv1', 'flt1', 'flt2', 'flt3', 'flt4', 'hh', 'kort7', 'kort9', 'logiz1', 'logiz2', 'logiz3', 'logiz4', 'os', 'shs1', 'spis1', 'spis2', 'spis3', 'spis4', 'spis44', 'spis5', 'spis55', 'strk1', 'strk2', 'strk3', 'strk4', 'tt1', 'tt2', 'tt3', 'tt4', 'vos1'] +``` + +По заданию была создана строка с фамилией и инициалами, преобразована в список, затем список – в кортеж, кортеж – в строку. + +``` +str0='Девятова М.Е.' +spis0=list(str0) +spis0 +['Д', 'е', 'в', 'я', 'т', 'о', 'в', 'а', ' ', 'М', '.', 'Е', '.'] +kort0=tuple(spis0); kort0 +('Д', 'е', 'в', 'я', 'т', 'о', 'в', 'а', ' ', 'М', '.', 'Е', '.') +str00=str(kort0); str00 +"('Д', 'е', 'в', 'я', 'т', 'о', 'в', 'а', ' ', 'М', '.', 'Е', '.')" +``` + +## 4 Арифметические операции. + +### 4.1 Сложение/вычитание. + +``` +12+7+90 +109 +5.689e-1 - 0.456 +0.11289999999999994 +23.6+54 +77.6 +14-56.7+89 +46.3 +``` + +### 4.2 Умножение. + +``` +-6.7*12 +-80.4 +``` + +### 4.3 Деление. + +``` +-234.5/6 +-39.083333333333336 +a=178/45; a; type(a) +3.9555555555555557 + +``` + +### 4.4 Деление с округлением вниз. + +``` +b=178//45; b; type(b) +3 + +c=-24.6//12.1; c; type(c) +-3.0 + +d=120//54.5; d; type(d) +2.0 + +e=120.1//54; e; type(e) +2.0 + +``` + +### 4.5 Получение остатка от деления. + +``` +148%33 +16 +12.6%3.8 +1.2000000000000002 +12.6%3 +0.5999999999999996 +12%3.8 +0.6000000000000005 +``` + +### 4.6 Возведение в степень. Операции над комплексными числами + +``` +14**3 +2744 +2.7**3.6 +35.719843790663525 +2.7**3 +19.683000000000003 +2**3.6 +12.125732532083186 +``` + +Были проделаны различные операции над комплексными числами. Операции деления с округлением вниз и получения остатка от деления не применяются для чисел такого типа. + +``` +c1=5+7j +c2=1-3j +c1+c2 +(6+4j) +c1-c2 +(4+10j) +c1*c2 +(26-8j) +c1/c2 +(-1.6+2.1999999999999997j) +c2**4.6 +(171.38366786889966+102.16827023666599j) +c1//2 +Traceback (most recent call last): + File "", line 1, in + c1//2 +TypeError: unsupported operand type(s) for //: 'complex' and 'int' +c1%c2 +Traceback (most recent call last): + File "", line 1, in + c1%c2 +TypeError: unsupported operand type(s) for %: 'complex' and 'complex' +``` + +## 5 Операции с двоичными представлениями целых чисел. + +### 5.1 Двоичная инверсия (~). + +Значение каждого бита в представлении числа заменяется на противоположное значение. + +``` +dv1=9; bin(dv1) +'0b1001' +dv2=~dv1; bin(dv2); dv2 +'-0b1010' +-10 +``` + +### 5.2 Двоичное «И» (&). + +Логическое умножение, возвращает 1, если оба соответствующих бита сравниваемых чисел равны 1. + +``` +dv3=7; dv4=8 +bin(dv3); bin(dv1) +'0b111' +'0b1001' +dv3&dv1 +1 +bin(dv3&dv1) +'0b1' +bin(dv3); bin(dv4) +'0b111' +'0b1000' +bin(dv3&dv4) +'0b0' +``` + +### 5.3 Двоичное «ИЛИ» (|). + +Логическое сложение, 0 получается, только если оба сравниваемых разряда равны 0. + +``` +bin(dv3); bin(dv1) +'0b111' +'0b1001' +dv3|dv1 +15 +bin(dv3|dv1) +'0b1111' +bin(dv3); bin(dv4) +'0b111' +'0b1000' +dv3|dv4 +15 +bin(dv3|dv4) +'0b1111' +dv5=5; dv6=14 +bin(dv5); bin(dv6) +'0b101' +'0b1110' +dv5|dv6 +15 +bin(dv5|dv6) +'0b1111' +``` + +### 5.4 Двоичное «исключающее ИЛИ»(^). + +Побитовое сравнение двоичных представлений чисел и 0 получается, только если оба сравниваемых разряда имеют одинаковые значения – оба 0 или оба 1. + +``` +bin(dv5); bin(dv6) +'0b101' +'0b1110' +dv5^dv6 +11 +bin(dv5^dv6) +'0b1011' +``` + +### 5.5 Сдвиг двоичного представления на заданное число разрядов влево (<<) или вправо (>>). + +``` +h=14; bin(h) +'0b1110' +g=h<<2; g; bin(g) +56 +'0b111000' +g1=h>>1; g1; bin(g1) +7 +'0b111' +g2=h>>2; g2; bin(g2) +3 +'0b11' +``` + +Были проделаны операции над двумя числами в двоичном представлении. + +``` +b1=int("0110011", 2); b2=int("0010110", 2); b1; b2 +51 +22 +bin(~b1) +'-0b110100' +~b1 +-52 +b1&b2; bin(b1&b2) +18 +'0b10010' +b1|b2; bin(b1|b2) +55 +'0b110111' +b1^b2; bin(b1^b2) +37 +'0b100101' +b1<<2; bin(b1<<2) +204 +'0b11001100' +b2>>3; bin(b2>>3) +2 +'0b10' +``` + +## 6 Операции при работе с последовательностями (строками, списками, кортежами). + +### 6.1 Объединение последовательностей (конкатенация)(+). + +``` +'Система '+'регулирования' +'Система регулирования' +['abc','de','fg']+['hi','jkl'] +['abc', 'de', 'fg', 'hi', 'jkl'] +('abc','de','fg')+('hi','jkl') +('abc', 'de', 'fg', 'hi', 'jkl') +``` + +### 6.2 Повторение (*). + +``` +'ля-'*5 +'ля-ля-ля-ля-ля-' +['ку','-']*3 +['ку', '-', 'ку', '-', 'ку', '-'] +('кис','-')*4 +('кис', '-', 'кис', '-', 'кис', '-', 'кис', '-') +signal1=[0]*3+[1]*99; signal1 +[0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1] +signal2=(0,)*3+(1,)*5+(0,)*7; signal2 +(0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0) +``` + +### 6.3 Проверка наличия заданного элемента в последовательности (in). + +``` +stroka='Система автоматического управления' +'автомат' in stroka +True +'ку' in ['ку','-']*3 +True +'ля-' in ('abc', 'de', 'fg', 'hi', 'jkl') +False +``` + +### 6.4 Подстановка значений в строку с помощью оператора «%». + +``` +stroka='Температура = %g %s %g' +stroka % (16,' меньше ',25) +'Температура = 16 меньше 25' +stroka='Температура = %(zn1)g %(sravn)s %(zn2)g' +stroka % {'zn1':16,'sravn':' меньше ','zn2':25} +'Температура = 16 меньше 25' +``` + +## 7 Оператор присваивания. + +### 7.1 Обычное присваивание значения переменной (=) + +``` +zz=-12 +``` + +### 7.2 Увеличение значения переменной на заданную величину (+=) или уменьшение (-=). + +Для последовательностей (например, строка) операция (+=) означает конкатенацию текущего значения объекта с заданным дополнением. + +``` +zz+=5; zz +-7 +zz-=3; zz +-10 +stroka='Система' +stroka+=' регулирования' +stroka +'Система регулирования' +``` + +### 7.3 Умножение текущего значения переменной на заданную величину (*=) или деление (/=). + +Для строк операция (*=) означает повторение текущего значения объекта заданное число раз. + +``` +zz/=2; zz +-5.0 +zz*=5; zz +-25.0 +stroka*=2; stroka +'Система регулированияСистема регулирования' +``` + +### 7.4 Операции деления с округлением вниз (//=), получения остатка от деления (%=) и возведения в степень (**=). + +``` +zz//=7; zz +-4.0 +zz%=3; zz +2.0 +zz +2.0 +zz**=5; zz +32.0 +``` + +### 7.5 Множественное присваивание. + +``` +w=v=10; w; v +10 +10 +n1,n2,n3=(11,-3,'all'); n1; n2; n3 +11 +-3 +'all' +n1,n2,n3="11","-3","all"; n1; n2; n3 +'11' +'-3' +'all' +n1,n2,n3=[11,-3,'all']; n1; n2; n3 +11 +-3 +'all' +n1,n2,n3={11: 0,-3: 3,'all': 1}; n1; n2; n3 +11 +-3 +'all' +n1,n2,n3={11,-3,'all'}; n1; n2; n3 +11 +'all' +-3 +``` + +## 8 Логические операции + +### 8.1 Операции сравнение: равенство (==), не равно (!=), меньше (<), больше (>), меньше или равно (<=), больше или равно (>=). + +``` +w==v +True +w!=v +False +v+=8 +w>v +False +w=w +True +v<=w +False +``` + +### 8.2 Проверка наличия заданного элемента в последовательности или во множестве, а также проверка наличия ключа в словаре (in). + +``` +mnoz1={'pen','book','pen','iPhone','table','book'} +'book' in mnoz1 +True +'cap' in mnoz1 +False +dic1={'Saratov':145, 'Orel':56, 'Vologda':45} +'Vologda' in dic1 +True +'Pskov' in dic1 +False +56 in dic1.values() +True +dct1={'Institut':['AVTI','IEE','IBB'],'Depart':['UII','PM','VMSS','MM'],'gruppa': ['A-01-15','A-02-15']} +'UII' in dct1['Depart'] +True +dct1['Depart'][1] == 'MM' +False +``` + +### 8.3 Создание больших логических выражений с использованием соединительных слов: логическое «И» (and), логическое «ИЛИ» (or), логическое «НЕ» (not). + +``` +a=17; b=-6 +(a>=b) and ('book' in mnoz1) and not ('Pskov' in dic1) +True +(a==b) or (145 in dic1.values()) or not ('VMSS' in dct1['Depart']) +True +(a>0) or ('pen' in mnoz1) and ('Moscow' in dic1) +False +``` + +### 8.4 Проверка ссылок переменных на один и тот же объект (is). + +``` +w=v=10 +w is v +True +w1=['A','B']; v1=['A','B'] +w1 is v1 +False +``` + +## 9 Операции с объектами, выполняемые с помощью методов. + +Полный список атрибутов объекта с использованием dir(): + +``` +dir(stroka) +['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill'] +``` + +### 9.1 Методы для работы со строками. + +``` +stroka.find('пр') +5 +stroka.count("с") +4 +stroka.replace(' у',' автоматического у') +'Микропроцессорная система автоматического управления' +spis22=stroka.split(' ') +spis22 +['Микропроцессорная', 'система', 'управления'] +stroka.upper() +'МИКРОПРОЦЕССОРНАЯ СИСТЕМА УПРАВЛЕНИЯ' +stroka3=" ".join(spis22); stroka3 +'Микропроцессорная система управления' +stroka3.partition("с") +('Микропроце', 'с', 'сорная система управления') +stroka3.rpartition("с") +('Микропроцессорная си', 'с', 'тема управления') +strk1='Момент времени {}, значение = {}' +strk1.format(1,89.7); strk1 +'Момент времени 1, значение = 89.7' +'Момент времени {}, значение = {}' +strk1.format(1,89.7) +'Момент времени 1, значение = 89.7' +strk2='Момент времени {1}, значение = {0}:{2}' +strk2.format(36.7,2,'норма!') +'Момент времени 2, значение = 36.7:норма!' +strk3='Момент времени {num}, значение = {znch}' +strk3.format(znch=89.7,num=2) +'Момент времени 2, значение = 89.7' +``` + +### 9.2 Методы работы со списками. + +``` +spsk=[1, 'abc', (8, 5), [2, 5], 1+7j] +spsk.pop(2); spsk +(8, 5) +[1, 'abc', [2, 5], (1+7j)] +spsk.append('c'); spsk +[1, 'abc', [2, 5], (1+7j), 'c'] +spsk.insert(2,'a'); spsk +[1, 'abc', 'a', [2, 5], (1+7j), 'c'] +spsk.count('a') +1 +``` + +### 9.3 Методы работы с кортежами. + +``` +kort_m=(1, 5, 8+6j, 'u') +dir(kort_m) +['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'count', 'index'] +kort_m.count(5) +1 +kort_m.index('u') +3 +``` + +### 9.4 Методы работы со словарями и множествами. + +Словари: + +``` +dict_m={'a': '21', 'b': 't', 'c': 90} +dir(dict_m) +['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values'] +dict_m.items() +dict_items([('a', '21'), ('b', 't'), ('c', 90)]) +dict_m.values() +dict_values(['21', 't', 90]) +dict_m.keys() +dict_keys(['a', 'b', 'c']) +dict_m.get('b') +'t' +dict_m.popitem() +('c', 90) +dict_m.pop('b') +'t' +dict_m +{'a': '21'} +dict_m.update({'v': 0, 'q': 'x'}) +dict_m +{'a': '21', 'v': 0, 'q': 'x'} +dict_m.clear() +dict_m +{} +``` + +Множества: + +``` +mn_m={'red','blue','green','black','blue'} +mn_m +{'green', 'red', 'blue', 'black'} +dir(mn_m) +['__and__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__iand__', '__init__', '__init_subclass__', '__ior__', '__isub__', '__iter__', '__ixor__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__rand__', '__reduce__', '__reduce_ex__', '__repr__', '__ror__', '__rsub__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__xor__', 'add', 'clear', 'copy', 'difference', 'difference_update', 'discard', 'intersection', 'intersection_update', 'isdisjoint', 'issubset', 'issuperset', 'pop', 'remove', 'symmetric_difference', 'symmetric_difference_update', 'union', 'update'] +mn_m.add('white') +mn_m +{'white', 'blue', 'black', 'red', 'green'} +mn_m.remove('green') +mn_m +{'white', 'blue', 'black', 'red'} +mn_m1=mn_m.copy() +mn_m1 +{'red', 'white', 'blue', 'black'} +mn_m1.add('yellow') +mn_m +{'white', 'blue', 'black', 'red'} +mn_m1 +{'white', 'blue', 'black', 'yellow', 'red'} +mn_m.difference(mn_m1) +set() +mn_m1.difference(mn_m) +{'yellow'} +mn_m2={'orange', 'violet', 'black'} +mn_m3=mn_m.union(mn_m2); mn_m3 +{'violet', 'white', 'blue', 'black', 'orange', 'red'} +mn_m3.symmetric_difference(mn_m2) +{'blue', 'white', 'red'} +mn_m3.intersection(mn_m2) +{'violet', 'black', 'orange'} +mn_m.issubset(mn_m1) +True +mn_m.isdisjoint(mn_m1) +False +``` \ No newline at end of file diff --git a/TEMA3/task.md b/TEMA3/task.md new file mode 100644 index 0000000..85d713f --- /dev/null +++ b/TEMA3/task.md @@ -0,0 +1,93 @@ +# Общее контрольное задание по теме 3 + +Девятова Мария, А-03-23 + +## Задание + +1) Преобразовать восьмеричное значение 45 в целое число. +2) Создать объект-словарь D со значениями {"усиление":23, "запаздывание":12, "постоянная времени":78} и затем осуществить его преобразование в два списка: ключей и значений, а затем – эти два списка преобразовать в один кортеж. Чем отличается кортеж от списка? +3) Напишите и выполните единое выражение, осуществляющее деление числа 1768 на 24.8 с округлением вниз, с определением после этого остатка от деления получившегося значения на 3 и затем возведения результата в степень 2.4. +4) Напишите и выполните единое выражение, последовательно осуществляющее следующие операции: двоичное И для чисел 13 и 27, инверсия полученного значения, двоичное исключающее ИЛИ для полученного значения и числа 14, сдвиг полученного значения на два разряда влево. +5) Создать список с 4 одинаковыми элементами 'колебат' и написать оператор проверки наличия комбинации символов 'аткол' в результате конкатенации второго и третьего элементов этого списка. +6) Определить список методов, доступных у ранее созданного словаря D. Поочередно использовать его методы keys и values, определить, что можно получить с применением этих методов. +7) Создать объект - символьную строку с текстом данного предложения. Из символьной строки создать список, элементами которого будут отдельные слова из созданной строки. Заменить в списке элемент «-» на «,». Удалить из списка элемент со значением «данного». Отобразить получившийся список. + +## Решение + +1) + +``` +int('45', 8) +37 +``` + +2) + +``` +D={"усиление":23, "запаздывание":12, "постоянная времени":78} +D_k=list(D.keys()); D_k +['усиление', 'запаздывание', 'постоянная времени'] +D_v=list(D.values()); D_v +[23, 12, 78] +K=tuple(D_k+D_v); K +('усиление', 'запаздывание', 'постоянная времени', 23, 12, 78) +``` + +3) + +``` +((1768//24.8)%3)**2.4 +5.278031643091577 +``` + +4) + +``` +((~(13&27))^14)<<2 +-32 +``` + +5) + +``` +spis=["колебат"]*4 +spis +['колебат', 'колебат', 'колебат', 'колебат'] +"аткол" in spis[1]+spis[2] +True +``` + +6) + +``` +dir(D) +['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values'] +help(D.keys) +Help on built-in function keys: + +keys() method of builtins.dict instance + Return a set-like object providing a view on the dict's keys. + +D.keys() +dict_keys(['усиление', 'запаздывание', 'постоянная времени']) +help(D.values) +Help on built-in function values: + +values() method of builtins.dict instance + Return an object providing a view on the dict's values. + +D.values() +dict_values([23, 12, 78]) +``` + +7) + +``` +strok='Создать объект - символьную строку с текстом данного предложения' +st_list=list(strok.split()); st_list +['Создать', 'объект', '-', 'символьную', 'строку', 'с', 'текстом', 'данного', 'предложения'] +st_list[st_list.index('-')]=','; st_list +['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'данного', 'предложения'] +st_list.remove('данного'); st_list +['Создать', 'объект', ',', 'символьную', 'строку', 'с', 'текстом', 'предложения'] +``` \ No newline at end of file