diff --git a/TEMA5/image-1.png b/TEMA5/image-1.png new file mode 100644 index 0000000..dd7b1bd Binary files /dev/null and b/TEMA5/image-1.png differ diff --git a/TEMA5/image.png b/TEMA5/image.png new file mode 100644 index 0000000..5bfc8cb Binary files /dev/null and b/TEMA5/image.png differ diff --git a/TEMA5/report.md b/TEMA5/report.md new file mode 100644 index 0000000..a353833 --- /dev/null +++ b/TEMA5/report.md @@ -0,0 +1,213 @@ +# Отчет по теме 5 + +Махнов Георгий, А-01-23 + +## Тема 5. Блоки инструкций, управляющие инструкции + +## 5 Блоки инструкций, управляющие инструкции + +### 2 Изучим ветвление по условию – управляющую инструкцию if +```py +>>> porog = 13 +>>> rashod1 = 8 +>>> rashod2 = 9 +>>> dohod = 5 +>>> if rashod1 >= porog: +... dohod = 12 +... elif rashod2 == porog: +... dohod = 0 +... else: +... dohod =- 8 +... +>>> dohod +-8 + +>>> if rashod1 >= porog: +... dohod = 12 +... elif rashod2 == porog: +... dohod = 0 +... else: +... dohod =- 8 +... +>>> dohod +-8 + +>>> if porog == 3: +... dohod = 1 +... elif porog == 4: +... dohod = 2 +... elif porog == 5: +... dohod = 3 +... else: +... dohod = 0 +... +>>> dohod +0 + +>>> dohod=2 if porog>=4 else 0 +>>> dohod +2 +>>> if porog>=5 : rashod1=6; rashod2=0 +... +>>> rashod1, rashod2 +(6, 0) +``` + +### 3 Изучим цикл по перечислению – управляющую инструкцию for + +#### 3.1 Простой цикл. + +```py +>>> temperatura = 5 +>>> for i in range(3, 18, 3): +... temperatura += i +... +>>> temperatura +50 +``` +#### 3.2 Более сложный цикл +```py +>>> sps = [2, 15, 14, 8] +>>> for k in sps: +... if len(sps) <= 10: sps.append(sps[0]) +... else: +... break +... +>>> sps +[2, 15, 14, 8, 2, 2, 2, 2, 2, 2, 2] + +>>> sps=[2,15,14,8] +>>> for k in sps[:]: +... if len(sps)<=10:sps.append(sps[0]) +... else:break +... +>>> sps +[2, 15, 14, 8, 2, 2, 2, 2] +``` +В первом случае мы идем по каждому элементу внутри списка sps. По условию, если длина списка не больше 10, то в него добавляется первый элемент списка - 2. Но так как мы все еще идем по элементам внутри списка, то по достижению последнего изначального элемента - 8, мы пойдем дальше по добавленным в список элементам (т.е по двойкам), пока не будет удовлетворено условие `if`, из-за чего длина этого списка равна 11. +Во втором случае при помощи среза [:] мы идем по первоначальным элементам списка, но не внутри самого списка, и при добавлении двоек в изначальный список цикл не будет продолжать работать после обработки последнего элемента первоначального списка, из-за чего длина списка равна 8. + +#### 3.3 Создание списка с 10 целыми случайными числами из диапазона от 1 до 100. При этом, если сум-ма чисел не превышает 500, эта сумма должна быть отображена на экране +```py +>>> import random as rn +>>> sps5=[] +>>> for i in range(10): +... sps5.append(rn.randint(1,100)) +... ss=sum(sps5) +... if ss>500: break +... else: +... print(ss) +... +>>> print(ss) +501 +``` +Программа не всегда выводит значения на экран. Это происходит из-за оператора `break`, который завершает цикл, если сумма ss первысила 500. В этом случае `else` не выполняется. +#### 3.4 Пример с символьной строкой +```py +>>> stroka='Это – автоматизированная система' +>>> stroka1="" +>>> for ss in stroka: +... stroka1+=" "+ss +... +>>> stroka +'Это – автоматизированная система' +>>> stroka1 +' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а' +``` +#### 3.5 Запись цикла в строке. +```py +>>> import math +>>> sps2=[math.sin(i*math.pi/5+2) for i in range(100)] +>>>import pylab +>>> pylab.plot(sps2) +[] +>>> pylab.show() +``` +Полученный график: ![alt text](image.png) + +### 4 Изучим цикл «пока истинно условие» – управляющую инструкцию while + +#### 4.1 Цикл со счетчиком. +```py +>>> rashod = 300 +>>> while rashod: +... print("Расход=",rashod) +... rashod-=50 +... +Расход= 300 +Расход= 250 +Расход= 200 +Расход= 150 +Расход= 100 +Расход= 50 +``` +Завершение цикла произошло в тот момент, когда переменная rashod стала равна нулю, завершив цикл, так как ноль как логическая переменная значит False. +#### 4.2 Пример с символьной строкой +```py +>>> stroka='Расчет процесса в объекте регулирования' +>>> i=0 +>>> sps2=[] +>>> while i>> T - 20 h - 8 e - 5 q - 17 u - 21 i - 9 c - 3 k - 11 , b - 2 r - 18 o - 15 w - 23 n - 14 f - 6 o - 15 x - 24 j - 10 u - 21 m - 13 p - 16 s - 19 o - 15 v - 22 e - 5 r - 18 t - 20 h - 8 e - 5 l - 12 a - 1 z - 26 y - 25 d - 4 o - 15 g - 7 . + +sentence_str = "Создайте список со словами из задания данного пункта. Для этого списка определите есть ли в нем некоторое заданное значение и выведите соответствующее сообщение либо о нахождении элемента либо о его отсутствии в списке проверить как с имеющимся так и с отсутствующим словом".split() + + +if input("Введите слово: ") in sentence_str: + print("Слово есть в предложении") +else: + print("Слова нет в предложении") +>>> Введите слово: либо +Слово есть в предложении + +>>> Введите слово: лихо +Слова нет в предложении + +surnames_summer = ['Коваленко', 'Лыкова', 'Лазарев'] +marks_summer = [4.75, 3.75, 5.00] +surnames_winter = ['Лыкова', 'Коваленко', 'Лазарев'] +marks_winter = [3.25, 4.5, 5.00] + +surname = input("Введите фамилию студента: ") +if surname in surnames_summer: + print(f"Студент {surname}. Средний балл за летнюю сессию составляет {marks_summer[surnames_summer.index(surname)]}, + за зимнюю сессию составляет {marks_winter[surnames_winter.index(surname)]}.") #перенос сделан для удобства проверки, в файле .py строка кода не переносится +else: + print(f"Студент {surname}. отсутствует в списке") + +>>>Введите фамилию студента: Лазарев +Студент Лазарев. Средний балл за летнюю сессию составляет 5.0, за зимнюю сессию составляет 5.0. + +>>>Введите фамилию студента: Махнов +Студент Махнов. отсутствует в списке + +``` \ No newline at end of file diff --git a/TEMA5/task.py b/TEMA5/task.py new file mode 100644 index 0000000..84a53c1 --- /dev/null +++ b/TEMA5/task.py @@ -0,0 +1,29 @@ +alphabet_list = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', +'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'] + +eng_str = "The quick, brown fox jumps over the lazy dog." +index_str = "" + +for letter in eng_str: + try: + index_str = index_str + f"{letter} - {str(alphabet_list.index(letter.lower()) + 1)} " + except ValueError: + index_str = index_str + letter +print(index_str) + +if input("Введите слово: ") in sentence_str: + print("Слово есть в предложении") +else: + print("Слова нет в предложении") + + +surnames_summer = ['Коваленко', 'Лыкова', 'Лазарев'] +marks_summer = [4.75, 3.75, 5.00] +surnames_winter = ['Лыкова', 'Коваленко', 'Лазарев'] +marks_winter = [3.25, 4.5, 5.00] + +surname = input("Введите фамилию студента: ") +if surname in surnames_summer: + print(f"Студент(ка) {surname}. Средний балл за летнюю сессию составляет {marks_summer[surnames_summer.index(surname)]}, за зимнюю сессию составляет {marks_winter[surnames_winter.index(surname)]}.") +else: + print(f"Студент(ка) {surname}. отсутствует в списке") \ No newline at end of file diff --git a/TEMA5/test.md b/TEMA5/test.md new file mode 100644 index 0000000..4e1567f --- /dev/null +++ b/TEMA5/test.md @@ -0,0 +1,23 @@ +# Индивидуальное контрольное задание по теме 5 + +Махнов Георгий, А-01-23 + +## Задание 9 + +9. Напишите инструкции создания списка с 20 случайными нормально распределенными (математическое ожидание равно -50, дисперсия равна 64) числами. Из этого списка перепишите в другой список только те элементы, которые не превышают среднего значения. + +## Решение + +```py +import random as rn + +sps = [rn.gauss(-50, 64**0.5) for i in range(20)] +print(f"{sps}, среднее = {sum(sps)/len(sps)} \n") +new_sps = [sps[i] for i in range(len(sps)) if sps[i]<=sum(sps)/len(sps)] + +print(new_sps) + +>>> [-48.42767862148211, -43.69035462933621, -61.0702207089155, -53.983411522362914, -46.71703779699627, -43.0128636534661, -36.739016417150715, -57.8461158532874, -40.051722914719875, -54.69110069704356, -53.21044543510062, -56.15437523954474, -63.130702927718104, -54.448990465321415, -54.90985201111035, -61.41046778390321, -83.6761467075842, -39.79673632158901, -46.536576715447765, -40.71362490760454], среднее = -52.010872066484225 + +[-61.0702207089155, -53.983411522362914, -57.8461158532874, -54.69110069704356, -53.21044543510062, -56.15437523954474, -63.130702927718104, -54.448990465321415, -54.90985201111035, -61.41046778390321, -83.6761467075842] +``` \ No newline at end of file diff --git a/TEMA5/test.py b/TEMA5/test.py new file mode 100644 index 0000000..20ba33e --- /dev/null +++ b/TEMA5/test.py @@ -0,0 +1,15 @@ + +''' +Напишите инструкции создания списка с 20 случайными нормально распределенными + (математическое ожидание равно -50, дисперсия равна 64) числами. + Из этого списка перепишите в другой список только те элементы, которые не превышают среднего значения. +''' + +import random as rn + +sps = [rn.gauss(-50, 64**0.5) for i in range(20)] +print(f"{sps}, среднее = {sum(sps)/len(sps)} \n") + +new_sps = [sps[i] for i in range(len(sps)) if sps[i]<=sum(sps)/len(sps)] + +print(new_sps)