форкнуто от main/python-labs
				
			
							Родитель
							
								
									b8a2291ec4
								
							
						
					
					
						Сommit
						ad43ebd841
					
				| 
		 После Ширина: | Высота: | Размер: 41 KiB  | 
| 
		 После Ширина: | Высота: | Размер: 19 KiB  | 
@ -0,0 +1,342 @@
 | 
				
			|||||||
 | 
					 # Отчет по Теме 5
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Беженарь Алёна, А-02-23
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Блоки инструкций, управляющие инструкции.
 | 
				
			||||||
 | 
					## 1. Настройка текущего каталога.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					import os
 | 
				
			||||||
 | 
					os.chdir("C:\\Users\\Дружок\\Desktop\\ПОАС\\python-labs\\TEMA4")
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					## 2. Ветвление по условию if()
 | 
				
			||||||
 | 
					Условие задается в виде логического выражения, которое может принимать значение True или False. 
 | 
				
			||||||
 | 
					Блок инструкций может располагаться на нескольких строках. Признак конца блока – отсутствие отступов в очередной строке или ввод пустой строки.
 | 
				
			||||||
 | 
					Пример 1 
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> porog, rashod1, rashod2 = 5, 10, 50
 | 
				
			||||||
 | 
					>>> if rashod1>=porog:
 | 
				
			||||||
 | 
					...   	dohod=12
 | 
				
			||||||
 | 
					... elif rashod2==porog:
 | 
				
			||||||
 | 
					...    	dohod=0
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...    	dohod=-8
 | 
				
			||||||
 | 
					>>> dohod
 | 
				
			||||||
 | 
					    12
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Пример 2 (условия внутри условия)
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> if rashod1>=3 and rashod2==4:
 | 
				
			||||||
 | 
					... 	dohod=rashod1
 | 
				
			||||||
 | 
					...	if rashod2==porog or rashod1<rashod2:
 | 
				
			||||||
 | 
					...        	dohod=porog     
 | 
				
			||||||
 | 
					>>> dohod
 | 
				
			||||||
 | 
					    12
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Пример 3 (ветвление линий потока)
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> if porog==3:
 | 
				
			||||||
 | 
					...		dohod=1
 | 
				
			||||||
 | 
					... elif porog==4:
 | 
				
			||||||
 | 
					...		dohod=2
 | 
				
			||||||
 | 
					... elif porog==5:
 | 
				
			||||||
 | 
					... 		dohod=3
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...		dohod=0
 | 
				
			||||||
 | 
					>>> dohod
 | 
				
			||||||
 | 
					    3
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Условные инструкции могут записываться также в одну строку в операторе присваивания по сле-дующей схеме:
 | 
				
			||||||
 | 
					<Объект>=<значение 1> if <условие>  else <значение 2> или ещё if <условие>: <инструкция1>[;<инструкция2>….]
 | 
				
			||||||
 | 
					Пример 4 (записи условий в одну строку)
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> dohod=2 if porog>=4 else 0
 | 
				
			||||||
 | 
					>>> dohod
 | 
				
			||||||
 | 
					    2
 | 
				
			||||||
 | 
					>>> if porog>=5 : rashod1=6; rashod2=0
 | 
				
			||||||
 | 
					    rashod1;rashod2
 | 
				
			||||||
 | 
					    6
 | 
				
			||||||
 | 
					    0
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					## 3. Цикл по перечислению for().
 | 
				
			||||||
 | 
					for <Объект-переменная цикла> in <объект>:
 | 
				
			||||||
 | 
						<отступы><Блок инструкций 1 – тело цикла>
 | 
				
			||||||
 | 
					[else: 
 | 
				
			||||||
 | 
						< отступы ><Блок инструкций 2 – если  в цикле не сработал break>], где
 | 
				
			||||||
 | 
					<объект> - любой определенный до начала цикла объект из классов строка, список, кортеж, множество, словарь.
 | 
				
			||||||
 | 
					<Объект-переменная цикла> - объект, в качестве значений которого поочередно будут задаваться элементы объекта, которые могут быть объектами любого типа. 
 | 
				
			||||||
 | 
					<Блок инструкций 1 – тело цикла> - совокупность инструкций, которая может содержать или не содержать инструкцию break, вызывающую досрочное завершение цикла при некоторых условиях. 
 | 
				
			||||||
 | 
					Если в цикле имеется необязательная часть: else и Блок инструкций 2, то он будет выполняться перед завершением цикла только в том случае, если при выполнении цикла не было его прерывания по инструкции break.
 | 
				
			||||||
 | 
					Пример 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]
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Выполним чуть-чуть отличающуюся совокупность операций:
 | 
				
			||||||
 | 
					```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]
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Для 1 случая:
 | 
				
			||||||
 | 
					Цикл работает непосредственно с исходным списком sps.
 | 
				
			||||||
 | 
					При каждом добавлении элемента (sps.append(sps[0])) длина списка увеличивается
 | 
				
			||||||
 | 
					Цикл будет выполняться бесконечно пока список не превысит 10 элементов, потому что список постоянно растет.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Для 2 случая:
 | 
				
			||||||
 | 
					Создается копия списка sps[:] перед началом цикла и сам цикл выполняется для фиксированного количества элементов (исходная длина списка)
 | 
				
			||||||
 | 
					Изменения исходного списка sps не влияют на выполнение цикла
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Пример 3.3
 | 
				
			||||||
 | 
					Конструкция for - else позволяет реализовать обычный цикл-перечисление с дополнительным условием, которое выполнится только в том случае, если работа цикла завершится самостоятельно (не в случае применения оператора break). Пример такого цикла представлен ниже:
 | 
				
			||||||
 | 
					```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)
 | 
				
			||||||
 | 
					... 
 | 
				
			||||||
 | 
					>>>     # Ничего не вывелость, т.к. сработал оператор break
 | 
				
			||||||
 | 
					>>> sps5 = []
 | 
				
			||||||
 | 
					>>> for i in range(10):
 | 
				
			||||||
 | 
					...     sps5.append(rn.randint(1, 100))
 | 
				
			||||||
 | 
					...     ss = sum(sps5)
 | 
				
			||||||
 | 
					...     if ss > 500: break
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...     print(ss)
 | 
				
			||||||
 | 
					...     
 | 
				
			||||||
 | 
					    481 # Цикл завершился самостоятельно, поэтому сработало дополнительное условие
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Пример 3.4 Работа с символьной строкой внутри цикла.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> stroka = "Это - автоматизированная система"
 | 
				
			||||||
 | 
					>>> stroka1 = ""
 | 
				
			||||||
 | 
					>>> for ss in stroka:
 | 
				
			||||||
 | 
					...     stroka1 += " " + ss # К каждому символу исходной строки добавлется пробел слева
 | 
				
			||||||
 | 
					...    
 | 
				
			||||||
 | 
					>>> stroka1
 | 
				
			||||||
 | 
					    ' Э т о   -   а в т о м а т и з и р о в а н н а я   с и с т е м а'
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Пример 3.5 Запись цикла в строке.
 | 
				
			||||||
 | 
					Цикл можно записать в строку. Такая запись представлена ниже на примере создания графика синусоидального сигнала:
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> import math, pylab
 | 
				
			||||||
 | 
					>>> sps2 = [math.sin(i * math.pi / 5 + 2) for i in range(100)] # Запись цикла в строку
 | 
				
			||||||
 | 
					>>> pylab.plot(list(range(100)), sps2)
 | 
				
			||||||
 | 
					    [<matplotlib.lines.Line2D object at 0x000002741F3CF850>]
 | 
				
			||||||
 | 
					>>> pylab.title("Синусоидальный сигнал")
 | 
				
			||||||
 | 
					    Text(0.5, 1.0, 'Синусоидальный сигнал')
 | 
				
			||||||
 | 
					>>> pylab.xlabel("Время")
 | 
				
			||||||
 | 
					    Text(0.5, 0, 'Время')
 | 
				
			||||||
 | 
					>>> pylab.ylabel("Сигнал")
 | 
				
			||||||
 | 
					    Text(0, 0.5, 'Сигнал')
 | 
				
			||||||
 | 
					>>> pylab.show()
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Полученный график:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 4. Изучение управляющей конструкции while.
 | 
				
			||||||
 | 
					Цикл, выполняющийся пока определенное условие истинно, реализуется с помощью конструкции while. В данном цикле нужно учесть возможность его прерывания, иначе, при постоянно истинном условии выполнения, цикл станет бесконечным, что приведет к большим проблемам в работе программы.
 | 
				
			||||||
 | 
					Пример 4.1. Цикл со счетчиком.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> rashod = 300
 | 
				
			||||||
 | 
					>>> while rashod:
 | 
				
			||||||
 | 
					...     print("Расход =", rashod)
 | 
				
			||||||
 | 
					...     rashod -= 50
 | 
				
			||||||
 | 
					...    
 | 
				
			||||||
 | 
					    Расход = 300
 | 
				
			||||||
 | 
					    Расход = 250
 | 
				
			||||||
 | 
					    Расход = 200
 | 
				
			||||||
 | 
					    Расход = 150
 | 
				
			||||||
 | 
					    Расход = 100
 | 
				
			||||||
 | 
					    Расход = 50
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Цикл в данном примере остановил свою работу, так как на 7 итерации значение переменной rashod достигло 0, что интерпретируется как значение False. Если бы данная переменная никогда не прнинимала значение 0, то получился бы бесконечный цикл.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Пример 4.2.
 | 
				
			||||||
 | 
					Как и в цикле for, в цикле while можно использовать символьные строки в качестве объекта, задающего условие прерывание цикла:
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> import math, pylab
 | 
				
			||||||
 | 
					>>> 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
 | 
				
			||||||
 | 
					... 
 | 
				
			||||||
 | 
					    Значение в момент 0 = 0.0
 | 
				
			||||||
 | 
					    Значение в момент 1 = 0.049958374957880025
 | 
				
			||||||
 | 
					    Значение в момент 2 = 0.09966799462495568
 | 
				
			||||||
 | 
					    Значение в момент 3 = 0.14888503362331795
 | 
				
			||||||
 | 
					    Значение в момент 4 = 0.197375320224904
 | 
				
			||||||
 | 
					    Значение в момент 5 = 0.2449186624037092
 | 
				
			||||||
 | 
					    Значение в момент 6 = 0.2913126124515909
 | 
				
			||||||
 | 
					    Значение в момент 7 = 0.3363755443363322
 | 
				
			||||||
 | 
					    Значение в момент 8 = 0.3799489622552249
 | 
				
			||||||
 | 
					    Значение в момент 9 = 0.421899005250008
 | 
				
			||||||
 | 
					    Значение в момент 10 = 0.4621171572600098
 | 
				
			||||||
 | 
					    Значение в момент 11 = 0.5005202111902354
 | 
				
			||||||
 | 
					    Значение в момент 12 = 0.5370495669980353
 | 
				
			||||||
 | 
					    Значение в момент 13 = 0.5716699660851172
 | 
				
			||||||
 | 
					    Значение в момент 14 = 0.6043677771171636
 | 
				
			||||||
 | 
					    Значение в момент 15 = 0.6351489523872873
 | 
				
			||||||
 | 
					    Значение в момент 16 = 0.6640367702678489
 | 
				
			||||||
 | 
					    Значение в момент 17 = 0.6910694698329307
 | 
				
			||||||
 | 
					    Значение в момент 18 = 0.7162978701990245
 | 
				
			||||||
 | 
					    Значение в момент 19 = 0.7397830512740043
 | 
				
			||||||
 | 
					    Значение в момент 20 = 0.7615941559557649
 | 
				
			||||||
 | 
					    Значение в момент 21 = 0.7818063576087741
 | 
				
			||||||
 | 
					    Значение в момент 22 = 0.8004990217606297
 | 
				
			||||||
 | 
					    Значение в момент 23 = 0.8177540779702878
 | 
				
			||||||
 | 
					    Значение в момент 24 = 0.8336546070121553
 | 
				
			||||||
 | 
					    Значение в момент 25 = 0.8482836399575129
 | 
				
			||||||
 | 
					    Значение в момент 26 = 0.8617231593133063
 | 
				
			||||||
 | 
					    Значение в момент 27 = 0.874053287886007
 | 
				
			||||||
 | 
					    Значение в момент 28 = 0.8853516482022625
 | 
				
			||||||
 | 
					    Значение в момент 29 = 0.8956928738431645
 | 
				
			||||||
 | 
					    Значение в момент 30 = 0.9051482536448664
 | 
				
			||||||
 | 
					    Значение в момент 31 = 0.9137854901178277
 | 
				
			||||||
 | 
					    Значение в момент 32 = 0.9216685544064713
 | 
				
			||||||
 | 
					    Значение в момент 33 = 0.9288576214547277
 | 
				
			||||||
 | 
					    Значение в момент 34 = 0.935409070603099
 | 
				
			||||||
 | 
					    Значение в момент 35 = 0.9413755384972874
 | 
				
			||||||
 | 
					    Значение в момент 36 = 0.9468060128462683
 | 
				
			||||||
 | 
					    Значение в момент 37 = 0.9517459571646616
 | 
				
			||||||
 | 
					    Значение в момент 38 = 0.9562374581277391
 | 
				
			||||||
 | 
					>>> pylab.plot(list(range(39)), sps2)
 | 
				
			||||||
 | 
					    [<matplotlib.lines.Line2D object at 0x00000274207FDC90>]
 | 
				
			||||||
 | 
					>>> pylab.title("Сигнал на выходе")
 | 
				
			||||||
 | 
					    Text(0.5, 1.0, 'Сигнал на выходе')
 | 
				
			||||||
 | 
					>>> pylab.xlabel("Время")
 | 
				
			||||||
 | 
					    Text(0.5, 0, 'Время')
 | 
				
			||||||
 | 
					>>> pylab.ylabel("Сигнал")
 | 
				
			||||||
 | 
					    Text(0, 0.5, 'Сигнал')
 | 
				
			||||||
 | 
					>>> pylab.show()
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Полученный график:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Пример 4.3. Выполнение сложного алгоритма с помощью цикла.
 | 
				
			||||||
 | 
					С помощью циклов можно реализовывать различные алгоритмы. Так, например, в примере ниже показан алгоритм проверки заданного числа на то, является ли оно простым.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> chislo = 267 #Проверяемое число
 | 
				
			||||||
 | 
					>>> kandidat = chislo // 2 # Для значений chislo > 1
 | 
				
			||||||
 | 
					>>> while kandidat > 1:
 | 
				
			||||||
 | 
					...     if chislo % kandidat == 0: # Остаток от деления
 | 
				
			||||||
 | 
					...         print(chislo, "имеет делитель", kandidat)
 | 
				
			||||||
 | 
					...         break # else выполняться не будет
 | 
				
			||||||
 | 
					...     kandidat -=1
 | 
				
			||||||
 | 
					... else: # При завершении цикла без break
 | 
				
			||||||
 | 
					...     print(chislo, "является простым")
 | 
				
			||||||
 | 
					...   
 | 
				
			||||||
 | 
					    267 имеет делитель 89
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					Данный алгоритм можно переработать для проверки некоторого диапазона чисел(например возьмем диапазон от 250 до 300):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> prost = [] # Список для записи в него простых чисел
 | 
				
			||||||
 | 
					>>> for num in range(250, 301): # Цикл, задающий диапазон рассматривыаемых значений
 | 
				
			||||||
 | 
					...     kandidat = num // 2
 | 
				
			||||||
 | 
					...     while kandidat > 1:
 | 
				
			||||||
 | 
					...         if num % kandidat == 0:
 | 
				
			||||||
 | 
					...             print(num, "имеет делитель", kandidat)
 | 
				
			||||||
 | 
					...             break
 | 
				
			||||||
 | 
					...         kandidat -= 1
 | 
				
			||||||
 | 
					...     else:
 | 
				
			||||||
 | 
					...         prost.append(num)
 | 
				
			||||||
 | 
					...         print(num, "является простым")
 | 
				
			||||||
 | 
					...       
 | 
				
			||||||
 | 
					    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 
 | 
				
			||||||
 | 
					>>> prost # Отображение списка простых чисел после работы алгоритма
 | 
				
			||||||
 | 
					    [251, 257, 263, 269, 271, 277, 281, 283, 293]
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Пример 4.3. Инструкция continue.
 | 
				
			||||||
 | 
					Инструкция continue позволяет завершить выполнение текущей итерации цикла и перейти к следующей:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> for i in range(7):
 | 
				
			||||||
 | 
					...     if i in [2, 3, 5]: # Если число равно 2, 3 или 5, то сразу же начинается новая итерация
 | 
				
			||||||
 | 
					...         continue
 | 
				
			||||||
 | 
					...    print(i)
 | 
				
			||||||
 | 
					...   
 | 
				
			||||||
 | 
					    0
 | 
				
			||||||
 | 
					    1
 | 
				
			||||||
 | 
					    4
 | 
				
			||||||
 | 
					    6
 | 
				
			||||||
 | 
					    7
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## 5. Завершение работы со средой.
 | 
				
			||||||
 | 
					Сохранила файлы отчета в своем рабочем каталоге и закончила сеанс работы с IDLE.
 | 
				
			||||||
@ -0,0 +1,88 @@
 | 
				
			|||||||
 | 
					# Общее контрольное задание по теме 5
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Беженарь Алёна, А-02-23
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Задание
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Реализовать, записать в текстовый файл программы и результаты их выполнения при решении следующих задач:
 | 
				
			||||||
 | 
					* Для заданной символьной строки с англоязычным текстом (его можно заимствовать из помощи) определите порядковый номер каждой буквы в английском алфавите.
 | 
				
			||||||
 | 
					* Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с отсутствующим словом).
 | 
				
			||||||
 | 
					* Создайте список студентов вашей группы (3-4 фамилии) и список их средних баллов в летней сессии – в порядке перечисления студентов в первом списке. Создайте еще 2 аналогичных списка для тех же студентов, но в другом порядке, по зимней сессии. Напишите инструкции, позволяющие по указанной (запрошенной и введенной) фамилии студента вывести его средние баллы по двум сессиям.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Решение
 | 
				
			||||||
 | 
					1.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> import string
 | 
				
			||||||
 | 
					>>> text = input("Введите строку на английском языке: ")
 | 
				
			||||||
 | 
					    Введите строку на английском языке: Hello world!
 | 
				
			||||||
 | 
					>>> for i in text:
 | 
				
			||||||
 | 
					...     if str.lower(i) in string.ascii_lowercase: #string.ascii_lowercase - это строка, содержащая все строчные буквы английского алфавита: 'abcdefghijklmnopqrstuvwxyz'
 | 
				
			||||||
 | 
					...         order = string.ascii_lowercase.index(str.lower(i)) + 1 #получение порядкого номера в английском алфавите.
 | 
				
			||||||
 | 
					...         print("Порядковый номер символа \"{}\" равен {}".format(i, order))
 | 
				
			||||||
 | 
					...     else:
 | 
				
			||||||
 | 
					...         print("Символа \"{}\" нет в английском алфавите".format(i))      
 | 
				
			||||||
 | 
					    Порядковый номер символа "H" равен 8
 | 
				
			||||||
 | 
					    Порядковый номер символа "e" равен 5
 | 
				
			||||||
 | 
					    Порядковый номер символа "l" равен 12
 | 
				
			||||||
 | 
					    Порядковый номер символа "l" равен 12
 | 
				
			||||||
 | 
					    Порядковый номер символа "o" равен 15
 | 
				
			||||||
 | 
					    Символа " " нет в английском алфавите
 | 
				
			||||||
 | 
					    Порядковый номер символа "w" равен 23
 | 
				
			||||||
 | 
					    Порядковый номер символа "o" равен 15
 | 
				
			||||||
 | 
					    Порядковый номер символа "r" равен 18
 | 
				
			||||||
 | 
					    Порядковый номер символа "l" равен 12
 | 
				
			||||||
 | 
					    Порядковый номер символа "d" равен 4
 | 
				
			||||||
 | 
					    Символа "!" нет в английском алфавите
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					2.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> string = """Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с отсутствующим словом)."""
 | 
				
			||||||
 | 
					>>> words = [word.strip('.,:;!?()–""') for word in string.split() if word.strip('.,:;!?()-–—""')] # Метод strip() позволяет убрать лишние символы с обеих сторон строки. По умолчанию он чистит пробелы, но если передать ему аргумент, то можно удалить и другие символы. (if word.strip('.,:;!?()-–—""') проверка на пустую строку)
 | 
				
			||||||
 | 
					>>> words 
 | 
				
			||||||
 | 
					    ['Создайте', 'список', 'со', 'словами', 'из', 'задания', 'данного', 'пункта', 'Для', 'этого', 'списка', 'определите', 'есть', 'ли', 'в', 'нем', 'некоторое', 'заданное', 'значение', 'и', 'выведите', 'соответствующее', 'сообщение', 'либо', 'о', 'нахождении', 'элемента', 'либо', 'о', 'его', 'отсутствии', 'в', 'списке', 'проверить', 'как', 'с', 'имеющимся', 'так', 'и', 'с', 'отсутствующим', 'словом']
 | 
				
			||||||
 | 
					>>> if input("Введите слово: ") in words:
 | 
				
			||||||
 | 
					...     print("Слово есть в списке")
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...     print("Слова нет в списке")
 | 
				
			||||||
 | 
					...   
 | 
				
			||||||
 | 
					    Введите слово: определите
 | 
				
			||||||
 | 
					    Слово есть в списке
 | 
				
			||||||
 | 
					>>> if input("Введите слово: ") in words:
 | 
				
			||||||
 | 
					...     print("Слово есть в списке")
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...     print("Слова нет в списке")
 | 
				
			||||||
 | 
					...    
 | 
				
			||||||
 | 
					    Введите слово: помогите
 | 
				
			||||||
 | 
					    Слова нет в списке
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					3.
 | 
				
			||||||
 | 
					```py
 | 
				
			||||||
 | 
					>>> students_summer = ["Беженарь", "Володин", "Ефимова", "Степанов"]
 | 
				
			||||||
 | 
					>>> marks_summer = [5, 4.5, 4.8, 4.6]
 | 
				
			||||||
 | 
					>>> students_winter = ["Степанов", "Ефимова","Володин", "Беженарь"]
 | 
				
			||||||
 | 
					>>> marks_winter = [4.9, 3.5, 4.3, 4.7]
 | 
				
			||||||
 | 
					>>> name = input("Введите фамилию студента: ")
 | 
				
			||||||
 | 
					    Введите фамилию студента: Ефимова
 | 
				
			||||||
 | 
					>>> if name in students_summer and name in students_winter:
 | 
				
			||||||
 | 
					...    	summer_mark = marks_summer[students_summer.index(name)]
 | 
				
			||||||
 | 
					...    	winter_mark = marks_winter[students_winter.index(name)]
 | 
				
			||||||
 | 
					...    	string = """Студент: {}\nОценка за летнюю сессию: {}\nОценка за зимнюю сессию: {}"""
 | 
				
			||||||
 | 
					...    	print(string.format(name, summer_mark, winter_mark))
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...     print("Студент {} не найден".format(name))
 | 
				
			||||||
 | 
					    Студент: Ефимова
 | 
				
			||||||
 | 
					    Оценка за летнюю сессию: 4.8
 | 
				
			||||||
 | 
					    Оценка за зимнюю сессию: 3.5
 | 
				
			||||||
 | 
					>>> name = input("Введите фамилию студента: ")
 | 
				
			||||||
 | 
					    Введите фамилию студента: Антонов
 | 
				
			||||||
 | 
					>>> if name in students_summer and name in students_winter:
 | 
				
			||||||
 | 
					...    	summer_mark = marks_summer[students_summer.index(name)]
 | 
				
			||||||
 | 
					...    	winter_mark = marks_winter[students_winter.index(name)]
 | 
				
			||||||
 | 
					...    	string = """Студент: {}\nОценка за летнюю сессию: {}\nОценка за зимнюю сессию: {}"""
 | 
				
			||||||
 | 
					...    	print(string.format(name, summer_mark, winter_mark))
 | 
				
			||||||
 | 
					... else:
 | 
				
			||||||
 | 
					...     print("Студент {} не найден".format(name))
 | 
				
			||||||
 | 
					    Студент Антонов не найден
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
					Загрузка…
					
					
				
		Ссылка в новой задаче