diff --git a/TEMA5/TEMA5report.md b/TEMA5/TEMA5report.md new file mode 100644 index 0000000..2f1d61f --- /dev/null +++ b/TEMA5/TEMA5report.md @@ -0,0 +1,375 @@ +# Отчет по теме 5 + +Шинкаренко Варвара, А-02-23 + +## 1. Настроили рабочий каталог + + +```py +import os +os.chdir('C:\\Users\\LENOVO\\Desktop\\python-labs\\TEMA5') +``` + +## 2. Ветвление по условию – управляющая инструкция if + +Выполняется первое условие: + +```py +porog = 43 +rashod1 = 52 +rashod2 = 67 +if rashod1 >= porog: + dohod = 12 +elif rashod2 == porog: + dohod = 0 +else: + dohod = -8 + +dohod +12 +``` + +Ни одно из условий не выполняется, значение переменной остаетсяя постоянным: + +```py +if rashod1 >= 3 and rashod2 == 4: + dohod = rashod1 + if rashod2 == porog or rashod1 < rashod2: + dohod = porog + +dohod +12 +``` + +Ни одно из условий не выполняется, следовательно выполняется последний блок инструкций: + +```py +if porog == 3: + dohod = 1 +elif porog == 4: + dohod = 2 +elif porog == 5: + dohod = 3 +else: + dohod = 0 + +dohod +0 +``` + +Запись условных инструкций в одну строку: + +```py +dohod = 2 if porog >=4 else 0 +dohod +2 # Первое условие выполнено + +if porog >= 5: rashod1 = 6; rashod2 = 0 # Записали несколько инструкций подряд +rashod1 +6 +rashod2 +0 + +``` + +## 3. Цикл по перечислению – управляющая инструкция for + +### 3.1 Простой цикл + +```py +temperatura = 5 +for i in range(3, 18, 3): + temperatura += i + +temperatura +50 +``` +Переменная i проходит значения от 3 до 18 с шагом 3, значит всего будет 5 значений i: 3, 6, 9, 12, 15 (правая граница не включается). +Тогда 5 + 3 + 6 + 9 + 12 + 15 = 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] +``` + +На каждом шаге выполняется проверка. Если длина списка меньше 10, в конец списка добавляется его первый элемент. Если длина списка становится больше 10, цикл прерывается. +При этом k пробегается по всем даже новым элементам списка и поэтому может делать это бесконечно, так как список постоянно увеличивается. Именно поэтому мы поставили условие на выход из цикла. (То есть для каждого элемента списка цикл прибаляет первый элемент в конец, и для k появляется новое значение, которое оно может принять.) +Можно посмотреть на этот цикл следующим образом: + +```py +for k in sps: + print('k = ', k, ', len = ', len(sps)) + if len(sps) <= 10: sps.append(sps[0]) + else: break + +k = 2 , len = 4 +k = 15 , len = 5 +k = 14 , len = 6 +k = 8 , len = 7 +k = 2 , len = 8 +k = 2 , len = 9 +k = 2 , len = 10 +k = 2 , len = 11 # Условие уже не выполняется, выходим из цикла +``` + +Попробуем другую инструкцию: + +```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] +``` +Результат отличен, так как срез списка по сути создает новый объект, постоянный в отличии от изменяемого в цикле объекта списка. +Поэтому теперь k проходится только по 4 элементам, так как срез не изменяется, что значит что else в принципе здесь не нужен, так как у нас есть заданное количество выполнений цикла(4) и длина списка не сможет достигнуть 10. + +### 3.3 Создание списка с помощью цикла + +```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) +``` + +Программа не вывела сумму, значит сработал выход из цикла. То есть переменная i не успела пробежаться по всем заданным значениям, значит и до else очередь не дошла. Проверим это посмотрев получившуюся сумму: + +```py +ss +541 # 541 > 500 +sps5 +[36, 83, 93, 22, 66, 15, 76, 13, 66, 71] +``` + +Видно что в конце успели добавить число в конец списка, но при этом увеличили сумму слишком сильно (до 71 было ss = 470) и поэтому досрочно вышли из цикла. Попробуем еще раз: + +```py +sps5 = [] +for i in range(10): + sps5.append(rn.randint(1, 100)) + ss = sum(sps5) + if ss > 500: break +else: + print(ss) + +439 # Программа выдала сумму сразу, значит цикл пройден до конца + +sps5 +[41, 81, 91, 52, 23, 30, 4, 44, 60, 13] +``` + +### 3.4 Пример с символьной строкой + +```py +stroka = 'Это автоматизированная система' +stroka1 = '' # Сначала пустая +for ss in stroka: + stroka1 += ' ' + ss # На каждом шаге прибаляется пробел и один элемент из строки (ss проходит по каждому элементу строки stroka) + +stroka1 +' Э т о а в т о м а т и з и р о в а н н а я с и с т е м а' +``` + +### 3.5 Запись цикла в строке + +```py +import math +sps2 = [math.sin(i*math.pi/5 + 2) for i in range(100)] +sps2 +[0.9092974268256817, 0.49103209793281005, -0.11479080280322804, -0.6767675184643197, -0.9802420445539634, -0.9092974268256817, -0.49103209793281016, 0.11479080280322791, 0.6767675184643196, 0.9802420445539634, ... +``` + +Создадим график: + +```py +pylab.plot(sps2, color = 'orange') +[] +pylab.title('Синусоида') +Text(0.5, 1.0, 'Синусоида') +pylab.xlabel('Значения i') +Text(0.5, 0, 'Значения i') +pylab.ylabel('Cигнал') +Text(0, 0.5, 'Cигнал') +pylab.show() +``` + +![График синусоиды](pics/Figure_1.png) + +## 4. Цикл «пока истинно условие» – управляющая инструкция while + +### 4.1 Цикл со счетчиком. + +```py +rashod = 300 +while rashod: + print('Расход = ', rashod) + rashod -= 50 + +Расход = 300 +Расход = 250 +Расход = 200 +Расход = 150 +Расход = 100 +Расход = 50 +``` + +Цикл работал пока rashod == True, соответсвенно выход из цикла произошел по значению rashod == 0 (то есть теперь rashod == False). + +### 4.2 Пример с символьной строкой + +```py +import math +stroka = 'Расчет процесса в объекте регулирования' +i=0 +sps2=[] +while i < len(stroka): + r = 1 - 2/(1 + math.exp(0.1*i)) + sps2.append(r) # Список дополняется в конце вычисленным значением + print('Значение в момент', i, "=", r) + i += 1 # Прибавляется один до тех пор, пока i не превышает длину строки. Тогда выходим из цикла по значению False + +Значение в момент 0 = 0.0 +Значение в момент 1 = 0.049958374957880025 +Значение в момент 2 = 0.09966799462495568 +Значение в момент 3 = 0.14888503362331795 +Значение в момент 4 = 0.197375320224904 +... +Значение в момент 38 = 0.9562374581277391 + +# Построили график +pylab.plot(sps2, color = 'green') +[] +pylab.title('Сигнал на выходе') +Text(0.5, 1.0, 'Сигнал на выходе') +pylab.show() +``` + +![График выходного сигнала](pics/Figure_2.png) + +### 4.3 Определение, является ли число простым + +```py +chislo = 267 +kandidat = chislo // 2 # Oкругление в меньшую сторону +while kandidat > 1: + if chislo%kandidat == 0: # Получение остатка от деления + print(chislo, 'имеет множитель', kandidat) + break + kandidat -= 1 +else: + print(chislo, 'является простым!') + +267 имеет множитель 89 +# Сначала делим на 2, затем с помощью цикла проверяем все числа от получившегося значения до 1, уменьшая kandidat на 1 в конце цикла. Если до 1 дошли, а деления без остатка так и не получили, то число является простым и выполняется блок инструкций после else. + +chislo = 11 +kandidat = chislo // 2 +while kandidat > 1: + if chislo%kandidat == 0: + print(chislo, 'имеет множитель', kandidat) + break + kandidat -= 1 +else: + print(chislo, 'является простым!') + +11 является простым! +``` + +Дополним так, чтобы выявить все простые числа от 250 до 300: + +```py +for i in range(250, 301): + chislo = i + kandidat = chislo // 2 + while kandidat > 1: + if chislo%kandidat == 0: + print(chislo, 'имеет множитель', kandidat) + break + kandidat -= 1 + else: + print(chislo, 'является простым!') + +250 имеет множитель 125 +251 является простым! +252 имеет множитель 126 +253 имеет множитель 23 +254 имеет множитель 127 +255 имеет множитель 85 +256 имеет множитель 128 +257 является простым! +258 имеет множитель 129 +259 имеет множитель 37 +260 имеет множитель 130 +261 имеет множитель 87 +262 имеет множитель 131 +263 является простым! +264 имеет множитель 132 +265 имеет множитель 53 +266 имеет множитель 133 +267 имеет множитель 89 +268 имеет множитель 134 +269 является простым! +270 имеет множитель 135 +271 является простым! +272 имеет множитель 136 +273 имеет множитель 91 +274 имеет множитель 137 +275 имеет множитель 55 +276 имеет множитель 138 +277 является простым! +278 имеет множитель 139 +279 имеет множитель 93 +280 имеет множитель 140 +281 является простым! +282 имеет множитель 141 +283 является простым! +284 имеет множитель 142 +285 имеет множитель 95 +286 имеет множитель 143 +287 имеет множитель 41 +288 имеет множитель 144 +289 имеет множитель 17 +290 имеет множитель 145 +291 имеет множитель 97 +292 имеет множитель 146 +293 является простым! +294 имеет множитель 147 +295 имеет множитель 59 +296 имеет множитель 148 +297 имеет множитель 99 +298 имеет множитель 149 +299 имеет множитель 23 +300 имеет множитель 150 +``` + +### 4.4 Инструкция continue + +```py +for i in range(1, 8): + if i == 4: + continue # Пропускаем значение i равное 4, переходим к следующему + else: + print(i) + +1 +2 +3 +5 +6 +7 +``` + +## 5. Завершили сеанс работы со средой \ No newline at end of file