Программирование на языке Python
Что такое цикл?
Повторения в программе
Блок-схема цикла
Как организовать цикл?
Цикл с условием
Считаем цифры
Максимальная цифра числа
Цикл с условием
Сколько раз выполняется цикл?
Алгоритм Евклида
Цикл с постусловием
472.50K
Category: programmingprogramming

Программирование на языке Python. Циклические алгоритмы

1. Программирование на языке Python

1
Программирование
на языке Python
§ 57. Циклические
алгоритмы
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

2. Что такое цикл?

Алгоритмы и программирование, язык Python, 10 класс
2
Что такое цикл?
Цикл – это многократное выполнение одинаковых
действий.
Два вида циклов:
• цикл с известным числом шагов (сделать 10 раз)
• цикл с неизвестным числом шагов (делать, пока не
надоест)
Задача. Вывести на экран 10 раз слово «Привет».
?
Можно ли решить известными методами?
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

3. Повторения в программе

Алгоритмы и программирование, язык Python, 10 класс
3
Повторения в программе
print("Привет“)
print("Привет")
...
print("Привет")
?
К.Ю. Поляков, Е.А. Ерёмин, 2018
Что плохо?
http://kpolyakov.spb.ru

4. Блок-схема цикла

Алгоритмы и программирование, язык Python, 10 класс
4
Блок-схема цикла
начало
сделали 10 раз?
да
конец
нет
print("Привет!")
тело цикла
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

5. Как организовать цикл?

Алгоритмы и программирование, язык Python, 10 класс
5
Как организовать цикл?
счётчик = 0
пока счётчик < 10:
print("Привет“)
увеличить счётчик на 1
счётчик = 10
пока счётчик > 0:
print("Привет")
уменьшить счётчик на 1
?
результат операции
автоматически
сравнивается с нулём!
Какой способ удобнее для процессора?
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

6. Цикл с условием

Алгоритмы и программирование, язык Python, 10 класс
6
Цикл с условием
Задача. Определить количество цифр в десятичной
записи целого положительного числа, записанного в
переменную n.
n
счётчик
счётчик = 0
пока n > 0:
1234
0
отсечь последнюю цифру n
123
1
увеличить счётчик на 1
12
2
?
Как отсечь последнюю цифру?
n = n // 10
?
1
0
3
4
Как увеличить счётчик на 1?
счётчик = счётчик + 1
К.Ю. Поляков, Е.А. Ерёмин, 2018
счётчик += 1
http://kpolyakov.spb.ru

7. Считаем цифры

Алгоритмы и программирование, язык Python, 10 класс
7
Считаем цифры
начальное значение
счётчика
заголовок
цикла
!
условие
продолжения
count = 0
while n > 0 :
n = n // 10
count += 1
тело цикла
Цикл с предусловием – проверка на входе в цикл!
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

8. Максимальная цифра числа

Алгоритмы и программирование, язык Python, 10 класс
8
Максимальная цифра числа
Задача. Определить максимальную цифру в
десятичной записи целого положительного числа,
записанного в переменную n.
n = int(input())
пока остались
M = -1
цифры
последняя while n > 0:
цифра
d = n % 10
if d > M:
? Что плохо!
поиск
M = d
максимума
n = n // 10
отсечь
print( M )
последнюю
цифру
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

9. Цикл с условием

Алгоритмы и программирование, язык Python, 10 класс
9
Цикл с условием
При известном количестве шагов:
k=0
while k < 10:
print ( "привет" )
k += 1
Зацикливание:
k=0
while k < 10:
print ( "привет" )
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

10. Сколько раз выполняется цикл?

Алгоритмы и программирование, язык Python, 10 класс
10
Сколько раз выполняется цикл?
a = 4; b = 6
while a < b: a += 1
2 раза
a=6
a = 4; b = 6
while a < b: a += b
1 раз
a = 10
a = 4; b = 6
while a > b: a += 1
0 раз
a=4
a = 4; b = 6
while a < b: b = a - b
1 раз
b = -2
a = 4; b = 6
while a < b: a -= 1
К.Ю. Поляков, Е.А. Ерёмин, 2018
зацикливание
http://kpolyakov.spb.ru

11. Алгоритм Евклида

Алгоритмы и программирование, язык Python, 10 класс
11
Алгоритм Евклида
Алгоритм Евклида. Чтобы найти НОД двух натуральных
чисел, нужно вычитать из большего числа меньшее до
тех пор, пока они не станут равны. Это число и есть
НОД исходных чисел.
НОД(14,21) = НОД(14,7) = НОД(7, 7) = 7
пока a != b:
если a > b:
a -= b # a = a - b
иначе:
b -= a # b = b - a
while a != b:
if a > b:
a -= b
else:
b -= a
НОД(1998,2) = НОД(1996,2) = … = НОД(2, 2) = 2
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru

12. Цикл с постусловием

Алгоритмы и программирование, язык Python, 10 класс
12
Цикл с постусловием
Задача. Обеспечить ввод положительного числа в
переменную n.
бесконечный
цикл
while True:
print ( "Введите положительное число:" )
n = int ( input() )
if n > 0: break
тело цикла
условие
прервать
выхода
цикл
• при входе в цикл условие не проверяется
• цикл всегда выполняется хотя бы один раз
К.Ю. Поляков, Е.А. Ерёмин, 2018
http://kpolyakov.spb.ru
English     Русский Rules