Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

7.9 KiB

Отчет по теме 5

Махнов Георгий, А-01-23

Тема 5. Блоки инструкций, управляющие инструкции

5 Блоки инструкций, управляющие инструкции

2 Изучим ветвление по условию – управляющую инструкцию if

>>> 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 Простой цикл.

>>> temperatura = 5
>>> for i in range(3, 18, 3):
...     temperatura += i
... 
>>> temperatura
50

3.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, 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, эта сумма должна быть отображена на экране

>>> 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 Пример с символьной строкой

>>> stroka='Это – автоматизированная система'
>>> stroka1=""
>>> for ss in stroka:
...     stroka1+=" "+ss
... 
>>> stroka
'Это – автоматизированная система'
>>> stroka1
' Э т о   –   а в т о м а т и з и р о в а н н а я   с и с т е м а'

3.5 Запись цикла в строке.

>>> import math
>>> sps2=[math.sin(i*math.pi/5+2) for i in range(100)]
>>>import pylab
>>> pylab.plot(sps2)
[<matplotlib.lines.Line2D object at 0x000001D6AA8730C8>]
>>> pylab.show()

Полученный график: alt text

4 Изучим цикл «пока истинно условие» – управляющую инструкцию while

4.1 Цикл со счетчиком.

>>> rashod = 300
>>> while rashod:
...     print("Расход=",rashod)
...     rashod-=50
... 
Расход= 300
Расход= 250
Расход= 200
Расход= 150
Расход= 100
Расход= 50

Завершение цикла произошло в тот момент, когда переменная rashod стала равна нулю, завершив цикл, так как ноль как логическая переменная значит False.

4.2 Пример с символьной строкой

>>> 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
... else:
...     pylab.plot(sps2)
...     pylab.show()
... 
Значение в момент 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

Полученный график: alt text

4.3 Определение, является ли число простым (делится только на самого себя или 1).

>>> chislo=267
>>> kandidat =chislo // 2
>>> while kandidat > 1:
...     if chislo%kandidat == 0:
...             print(chislo, ' имеет множитель ', kandidat)
...             break
...     kandidat -= 1
... else:
...     print(chislo, ' является простым!')
... 
267  имеет множитель  89