diff --git a/TEMA5/report.md b/TEMA5/report.md index 013a9ac..5000766 100644 --- a/TEMA5/report.md +++ b/TEMA5/report.md @@ -8,18 +8,44 @@ ## 2. Ветвление по условию – управляющая инструкция if. ```py >>> porog=50 ->>> rashod1=150 ->>> if rashod1 >= porog: -... dohod = 12 -... elif rashod2 == porog: -... dohod = 0 +>>> rashod1=100 +>>> rashod2=150 +>>> if rashod1>=porog: +... dohod=12 +... elif rashod2==porog: +... dohod=0 ... else: -... dohod = -8 # Это выполняется, если ни первое, ни второе условия не были истинными +... dohod=-8 ... +... >>> dohod 12 ``` ```py +>>> porog=10 +>>> rashod1=11 +>>> rashod2=4 +>>> if rashod1>=3 and rashod2==4: +... dohod=rashod1 +... if rashod2==porog or rashod1>> dohod +11 +``` +```py +>>> dohod=2 if porog>=4 else 0 +>>> dohod +2 +>>> if porog>=5 : rashod1=6; rashod2=0 +... +>>> rashod1 +6 +>>> rashod2 +0 +``` +```py >>> rashod1=8 >>> rashod2=4 >>> porog=4 @@ -34,17 +60,6 @@ else: >>> dohod 2 ``` -```py ->>> dohod=2 if porog>=4 else 0 ->>> dohod -2 ->>> if porog>=5 : rashod1=6; rashod2=0 -... ->>> rashod1 -8 ->>> rashod2 -4 -``` ## 3. Цикл по перечислению – управляющая инструкция for. 3.1 Простой цикл ```py @@ -66,43 +81,46 @@ else: >>> sps [2, 15, 14, 8, 2, 2, 2, 2, 2, 2, 2] ``` +Цикл выполняет тело (добавление 2 в конец списка), до тех пор пока длина этого списка не превысит 10. Получается список длиной 11. ```py >>> sps=[2,15,14,8] >>> for k in sps[:]: - if len(sps)<=10:sps.append(sps[0]) - else:break - +... if len(sps)<=10:sps.append(sps[0]) +... else:break +... +... >>> sps [2, 15, 14, 8, 2, 2, 2, 2] ``` -Цикл выполняет тело (добавление 2 в конец списка), до тех пор пока длина этого списка не превысит 10. Получается список длиной 11. - +Здесь список, по которому пробегается k, и список, изменяющийся внутри цикла - это объекты, имеющие разные адреса. Цикл итерируется по копии, но изменяет оригинальный список sps. Итерации происходят только 4 раза 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) - -402 +... sps5.append(rn.randint(1,100)) +... ss=sum(sps5) +... if ss>500: break +... else: +... print(ss) +... +488 ``` +Программа вывела ответ, потому что сработал else, и за все десять итераций цикла так и не успел выполниться break по условию if. +```py >>> for i in range(10): - sps5.append(rn.randint(1,100)) - ss=sum(sps5) - if ss>500: break -else: print(ss) - +... sps5.append(rn.randint(1,100)) +... ss=sum(sps5) +... if ss>500: break +... else: +... print(ss) +... +... >>> ss -546 ->>> sps5 -[73, 74, 24, 43, 15, 90, 14, 4, 35, 30, 40, 57, 47] +569 ``` -После того, как прошло девять итераций, сумма элементов списка уже была больше 500, поэтому цикл закончился из-за if, а не из-за окончания диапазона range(10). +Сумма превысила 500 и сработала команда break 3.4 Пример с символьной строкой @@ -115,6 +133,8 @@ else: print(ss) >>> stroka1 ' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а' ``` +Переменная ss проходит по всему строковому объекту, на каждой итерации принимая значение одного знака. Этот знак с предшествующим пробелом дописывается в конец другой, изначально пустой строки. Цикл закончится, когда закончится исходная строка. + 3.5 Запись цикла в строке ```py >>> import math @@ -123,6 +143,7 @@ else: print(ss) [0.9092974268256817, 0.49103209793281005, -0.11479080280322804, -0.6767675184643197, -0.9802420445539634, -0.9092974268256817, -0.49103209793281016, 0.11479080280322791, 0.6767675184643196, 0.9802420445539634, 0.9092974268256818, 0.4910320979328103, -0.1147908028032278, -0.6767675184643196, -0.9802420445539632, -0.9092974268256818, -0.4910320979328104, 0.11479080280322768, 0.6767675184643195, 0.9802420445539632, 0.9092974268256819, 0.4910320979328105, -0.11479080280322579, -0.6767675184643194, -0.9802420445539632, -0.9092974268256819, -0.4910320979328106, 0.11479080280322743, 0.6767675184643193, 0.9802420445539632, 0.909297426825682, 0.49103209793281066, -0.1147908028032273, -0.6767675184643192, -0.9802420445539632, -0.909297426825682, -0.4910320979328108, 0.11479080280322719, 0.6767675184643192, 0.9802420445539631, 0.9092974268256822, 0.491032097932814, -0.11479080280322707, -0.676767518464319, -0.9802420445539625, -0.9092974268256822, -0.491032097932811, 0.11479080280323047, 0.6767675184643189, 0.9802420445539625, 0.9092974268256822, 0.4910320979328142, -0.11479080280322682, -0.6767675184643215, -0.9802420445539631, -0.9092974268256808, -0.4910320979328112, 0.11479080280322317, 0.6767675184643187, 0.9802420445539624, 0.9092974268256823, 0.4910320979328082, -0.11479080280322658, -0.6767675184643213, -0.980242044553963, -0.9092974268256838, -0.49103209793281144, 0.11479080280322293, 0.6767675184643186, 0.9802420445539637, 0.9092974268256824, 0.49103209793280844, -0.11479080280322633, -0.6767675184643158, -0.980242044553963, -0.9092974268256839, -0.49103209793281166, 0.11479080280322974, 0.6767675184643184, 0.9802420445539637, 0.9092974268256825, 0.4910320979328149, -0.11479080280321903, -0.6767675184643209, -0.9802420445539629, -0.909297426825681, -0.4910320979328119, 0.11479080280322244, 0.6767675184643129, 0.9802420445539636, 0.9092974268256826, 0.49103209793281505, -0.11479080280322584, -0.6767675184643155, -0.9802420445539644, -0.9092974268256812, -0.49103209793281205, 0.1147908028032222, 0.6767675184643127, 0.980242044553965] ``` + ## 4. Цикл «пока истинно условие» – управляющая инструкция while. 4.1 Цикл со счетчиком. ```py @@ -193,6 +214,7 @@ else: print(ss) Значение в момент 38 = 0.9562374581277391 ``` + 4.3 Определение, является ли число простым (делится только на самого себя или 1) ```py >>> chislo=267 #Проверяемое число diff --git a/TEMA5/task.md b/TEMA5/task.md index 0024865..0252f52 100644 --- a/TEMA5/task.md +++ b/TEMA5/task.md @@ -73,6 +73,10 @@ • Создайте список со словами из задания данного пункта. Для этого списка – определите, есть ли в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с отсутствующим словом). ```py +>>> text="Создайте список со словами из задания данного пункта Для этого списка определите есть ли в нем некоторое заданное значение и выведите соответствующее сообщение либо о нахождении элемента либо о его отсутствии в списке проверить как с имеющимся так и с отсутствующим словом" +>>> spis=text.split(" ") +>>> spis +['Создайте', 'список', 'со', 'словами', 'из', 'задания', 'данного', 'пункта', 'Для', 'этого', 'списка', 'определите', 'есть', 'ли', 'в', 'нем', 'некоторое', 'заданное', 'значение', 'и', 'выведите', 'соответствующее', 'сообщение', 'либо', 'о', 'нахождении', 'элемента', 'либо', 'о', 'его', 'отсутствии', 'в', 'списке', 'проверить', 'как', 'с', 'имеющимся', 'так', 'и', 'с', 'отсутствующим', 'словом'] >>> slovo="список" # Цикл с имеющимся словом в списке >>> for x in spis: ... if x ==slovo: @@ -96,7 +100,7 @@ ``` • Создайте список студентов вашей группы (3-4 фамилии) и список их средних баллов в летней сессии – в порядке перечисления студентов в первом списке. Создайте еще 2 аналогичных списка для тех же студентов, но в другом порядке, по зимней сессии. Напишите инструкции, позволяющие по указанной (запрошенной и введенной) фамилии студента вывести его средние баллы по двум сессиям. ```py -pis=['Berezhkov', 'Tabolin', 'Filippov'] +spis=['Berezhkov', 'Tabolin', 'Filippov'] spis1=[3.2, 2.6, 4.2] spis2=[3.0,3.7,4.0] spis3=['Tabolin', 'Filippov', 'Berezhkov']