форкнуто от main/python-labs
Родитель
2ff5382146
Сommit
35a8e9c4e5
|
После Ширина: | Высота: | Размер: 22 KiB |
|
После Ширина: | Высота: | Размер: 59 KiB |
@ -0,0 +1,213 @@
|
||||
# Отчет по теме 5
|
||||
|
||||
Махнов Георгий, А-01-23
|
||||
|
||||
## Тема 5. Блоки инструкций, управляющие инструкции
|
||||
|
||||
## 5 Блоки инструкций, управляющие инструкции
|
||||
|
||||
### 2 Изучим ветвление по условию – управляющую инструкцию if
|
||||
```py
|
||||
>>> 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 Простой цикл.
|
||||
|
||||
```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]
|
||||
|
||||
>>> 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, эта сумма должна быть отображена на экране
|
||||
```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)
|
||||
...
|
||||
>>> print(ss)
|
||||
501
|
||||
```
|
||||
Программа не всегда выводит значения на экран. Это происходит из-за оператора `break`, который завершает цикл, если сумма ss первысила 500. В этом случае `else` не выполняется.
|
||||
#### 3.4 Пример с символьной строкой
|
||||
```py
|
||||
>>> stroka='Это – автоматизированная система'
|
||||
>>> stroka1=""
|
||||
>>> for ss in stroka:
|
||||
... stroka1+=" "+ss
|
||||
...
|
||||
>>> stroka
|
||||
'Это – автоматизированная система'
|
||||
>>> stroka1
|
||||
' Э т о – а в т о м а т и з и р о в а н н а я с и с т е м а'
|
||||
```
|
||||
#### 3.5 Запись цикла в строке.
|
||||
```py
|
||||
>>> 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()
|
||||
```
|
||||
Полученный график: 
|
||||
|
||||
### 4 Изучим цикл «пока истинно условие» – управляющую инструкцию while
|
||||
|
||||
#### 4.1 Цикл со счетчиком.
|
||||
```py
|
||||
>>> rashod = 300
|
||||
>>> while rashod:
|
||||
... print("Расход=",rashod)
|
||||
... rashod-=50
|
||||
...
|
||||
Расход= 300
|
||||
Расход= 250
|
||||
Расход= 200
|
||||
Расход= 150
|
||||
Расход= 100
|
||||
Расход= 50
|
||||
```
|
||||
Завершение цикла произошло в тот момент, когда переменная rashod стала равна нулю, завершив цикл, так как ноль как логическая переменная значит False.
|
||||
#### 4.2 Пример с символьной строкой
|
||||
```py
|
||||
>>> 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
|
||||
```
|
||||
Полученный график: 
|
||||
#### 4.3 Определение, является ли число простым (делится только на самого себя или 1).
|
||||
```py
|
||||
>>> chislo=267
|
||||
>>> kandidat =chislo // 2
|
||||
>>> while kandidat > 1:
|
||||
... if chislo%kandidat == 0:
|
||||
... print(chislo, ' имеет множитель ', kandidat)
|
||||
... break
|
||||
... kandidat -= 1
|
||||
... else:
|
||||
... print(chislo, ' является простым!')
|
||||
...
|
||||
267 имеет множитель 89
|
||||
```
|
||||
@ -0,0 +1,60 @@
|
||||
# Общее контрольное задание по теме 5
|
||||
|
||||
Махнов Георгий, А-01-23
|
||||
|
||||
## Задание
|
||||
|
||||
• Для заданной символьной строки с англоязычным текстом (его можно заимствовать из помощи) определите порядковый номер каждой буквы в английском алфавите.
|
||||
• Создайте список со словами из задания данного пункта. Для этого списка определите, есть ли в нем некоторое заданное значение, и выведите соответствующее сообщение: либо о нахождении элемента, либо о его отсутствии в списке (проверить как с имеющимся, так и с отсутствующим словом).
|
||||
• Создайте список студентов вашей группы (3-4 фамилии) и список их средних баллов в летней сессии – в порядке перечисления студентов в первом списке. Создайте еще 2 аналогичных списка для тех же студентов, но в другом порядке, по зимней сессии. Напишите инструкции, позволяющие по указанной (запрошенной и введенной) фамилии студента вывести его сред-ние баллы по двум сессиям.
|
||||
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
alphabet_list = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
|
||||
'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
|
||||
|
||||
eng_str = "The quick, brown fox jumps over the lazy dog."
|
||||
index_str = ""
|
||||
for letter in eng_str:
|
||||
try:
|
||||
index_str = index_str + f"{letter} - {str(alphabet_list.index(letter.lower()) + 1)} "
|
||||
except ValueError:
|
||||
index_str = index_str + letter
|
||||
print(index_str)
|
||||
|
||||
>>> T - 20 h - 8 e - 5 q - 17 u - 21 i - 9 c - 3 k - 11 , b - 2 r - 18 o - 15 w - 23 n - 14 f - 6 o - 15 x - 24 j - 10 u - 21 m - 13 p - 16 s - 19 o - 15 v - 22 e - 5 r - 18 t - 20 h - 8 e - 5 l - 12 a - 1 z - 26 y - 25 d - 4 o - 15 g - 7 .
|
||||
|
||||
sentence_str = "Создайте список со словами из задания данного пункта. Для этого списка определите есть ли в нем некоторое заданное значение и выведите соответствующее сообщение либо о нахождении элемента либо о его отсутствии в списке проверить как с имеющимся так и с отсутствующим словом".split()
|
||||
|
||||
|
||||
if input("Введите слово: ") in sentence_str:
|
||||
print("Слово есть в предложении")
|
||||
else:
|
||||
print("Слова нет в предложении")
|
||||
>>> Введите слово: либо
|
||||
Слово есть в предложении
|
||||
|
||||
>>> Введите слово: лихо
|
||||
Слова нет в предложении
|
||||
|
||||
surnames_summer = ['Коваленко', 'Лыкова', 'Лазарев']
|
||||
marks_summer = [4.75, 3.75, 5.00]
|
||||
surnames_winter = ['Лыкова', 'Коваленко', 'Лазарев']
|
||||
marks_winter = [3.25, 4.5, 5.00]
|
||||
|
||||
surname = input("Введите фамилию студента: ")
|
||||
if surname in surnames_summer:
|
||||
print(f"Студент {surname}. Средний балл за летнюю сессию составляет {marks_summer[surnames_summer.index(surname)]},
|
||||
за зимнюю сессию составляет {marks_winter[surnames_winter.index(surname)]}.") #перенос сделан для удобства проверки, в файле .py строка кода не переносится
|
||||
else:
|
||||
print(f"Студент {surname}. отсутствует в списке")
|
||||
|
||||
>>>Введите фамилию студента: Лазарев
|
||||
Студент Лазарев. Средний балл за летнюю сессию составляет 5.0, за зимнюю сессию составляет 5.0.
|
||||
|
||||
>>>Введите фамилию студента: Махнов
|
||||
Студент Махнов. отсутствует в списке
|
||||
|
||||
```
|
||||
@ -0,0 +1,29 @@
|
||||
alphabet_list = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
|
||||
'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
|
||||
|
||||
eng_str = "The quick, brown fox jumps over the lazy dog."
|
||||
index_str = ""
|
||||
|
||||
for letter in eng_str:
|
||||
try:
|
||||
index_str = index_str + f"{letter} - {str(alphabet_list.index(letter.lower()) + 1)} "
|
||||
except ValueError:
|
||||
index_str = index_str + letter
|
||||
print(index_str)
|
||||
|
||||
if input("Введите слово: ") in sentence_str:
|
||||
print("Слово есть в предложении")
|
||||
else:
|
||||
print("Слова нет в предложении")
|
||||
|
||||
|
||||
surnames_summer = ['Коваленко', 'Лыкова', 'Лазарев']
|
||||
marks_summer = [4.75, 3.75, 5.00]
|
||||
surnames_winter = ['Лыкова', 'Коваленко', 'Лазарев']
|
||||
marks_winter = [3.25, 4.5, 5.00]
|
||||
|
||||
surname = input("Введите фамилию студента: ")
|
||||
if surname in surnames_summer:
|
||||
print(f"Студент(ка) {surname}. Средний балл за летнюю сессию составляет {marks_summer[surnames_summer.index(surname)]}, за зимнюю сессию составляет {marks_winter[surnames_winter.index(surname)]}.")
|
||||
else:
|
||||
print(f"Студент(ка) {surname}. отсутствует в списке")
|
||||
@ -0,0 +1,23 @@
|
||||
# Индивидуальное контрольное задание по теме 5
|
||||
|
||||
Махнов Георгий, А-01-23
|
||||
|
||||
## Задание 9
|
||||
|
||||
9. Напишите инструкции создания списка с 20 случайными нормально распределенными (математическое ожидание равно -50, дисперсия равна 64) числами. Из этого списка перепишите в другой список только те элементы, которые не превышают среднего значения.
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
import random as rn
|
||||
|
||||
sps = [rn.gauss(-50, 64**0.5) for i in range(20)]
|
||||
print(f"{sps}, среднее = {sum(sps)/len(sps)} \n")
|
||||
new_sps = [sps[i] for i in range(len(sps)) if sps[i]<=sum(sps)/len(sps)]
|
||||
|
||||
print(new_sps)
|
||||
|
||||
>>> [-48.42767862148211, -43.69035462933621, -61.0702207089155, -53.983411522362914, -46.71703779699627, -43.0128636534661, -36.739016417150715, -57.8461158532874, -40.051722914719875, -54.69110069704356, -53.21044543510062, -56.15437523954474, -63.130702927718104, -54.448990465321415, -54.90985201111035, -61.41046778390321, -83.6761467075842, -39.79673632158901, -46.536576715447765, -40.71362490760454], среднее = -52.010872066484225
|
||||
|
||||
[-61.0702207089155, -53.983411522362914, -57.8461158532874, -54.69110069704356, -53.21044543510062, -56.15437523954474, -63.130702927718104, -54.448990465321415, -54.90985201111035, -61.41046778390321, -83.6761467075842]
|
||||
```
|
||||
@ -0,0 +1,15 @@
|
||||
|
||||
'''
|
||||
Напишите инструкции создания списка с 20 случайными нормально распределенными
|
||||
(математическое ожидание равно -50, дисперсия равна 64) числами.
|
||||
Из этого списка перепишите в другой список только те элементы, которые не превышают среднего значения.
|
||||
'''
|
||||
|
||||
import random as rn
|
||||
|
||||
sps = [rn.gauss(-50, 64**0.5) for i in range(20)]
|
||||
print(f"{sps}, среднее = {sum(sps)/len(sps)} \n")
|
||||
|
||||
new_sps = [sps[i] for i in range(len(sps)) if sps[i]<=sum(sps)/len(sps)]
|
||||
|
||||
print(new_sps)
|
||||
Загрузка…
Ссылка в новой задаче