форкнуто от main/python-labs
Родитель
0460d49355
Сommit
31aea12869
@ -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')
|
||||
[<matplotlib.lines.Line2D object at 0x0000027610BF0690>]
|
||||
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()
|
||||
```
|
||||
|
||||

|
||||
|
||||
## 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')
|
||||
[<matplotlib.lines.Line2D object at 0x00000276105D8A50>]
|
||||
pylab.title('Сигнал на выходе')
|
||||
Text(0.5, 1.0, 'Сигнал на выходе')
|
||||
pylab.show()
|
||||
```
|
||||
|
||||

|
||||
|
||||
### 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. Завершили сеанс работы со средой
|
||||
Загрузка…
Ссылка в новой задаче