Основы программирования (на языке Си). Циклические алгоритмы

Содержание

Слайд 2

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

Цикл – это многократное выполнение одинаковых действий.

Два вида циклов:
цикл с

Что такое цикл? Цикл – это многократное выполнение одинаковых действий. Два вида
известным числом шагов (сделать 10 раз)
цикл с неизвестным числом шагов (делать, пока не надоест)

Задача. Вывести на экран 10 раз слово «Привет».

Слайд 3

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

printf("Привет\n");
printf("Привет\n");
...
printf("Привет\n");

Повторения в программе printf("Привет\n"); printf("Привет\n"); ... printf("Привет\n");

Слайд 4

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

начало

конец

да

нет

тело цикла

Блок-схема цикла начало конец да нет тело цикла

Слайд 5

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

счётчик = 0
пока счётчик < 10
printf("Привет\n");
увеличить счётчик на

Как организовать цикл? счётчик = 0 пока счётчик printf("Привет\n"); увеличить счётчик на
1

счётчик = 10
пока счётчик > 0
printf("Привет\n");
уменьшить счётчик на 1


результат операции автоматически сравнивается с нулём!

Слайд 6

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

Задача. Определить количество цифр в десятичной записи целого положительного числа,

Цикл с условием Задача. Определить количество цифр в десятичной записи целого положительного
записанного в переменную n.

счётчик = 0
пока n > 0
отсечь последнюю цифру n
увеличить счётчик на 1

n = n / 10;

счётчик = счётчик + 1;

счётчик ++;

Слайд 7

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

count = 0;
while ( )
{
}

n = n /

Цикл с условием count = 0; while ( ) { } n
10;
count ++;

тело цикла

начальное значение счётчика

n > 0

условие продолжения

заголовок цикла

конец цикла

Слайд 8

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

k = 0;
while ( k < 10 )
{

Цикл с условием k = 0; while ( k { printf (
printf ( "привет\n" );
k ++;
}

При известном количестве шагов:

k = 0;
while ( k < 10 )
{
printf ( "привет\n" );
}

Зацикливание:

Слайд 9

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

a = 4; b = 6;
while ( a <

Сколько раз выполняется цикл? a = 4; b = 6; while (
b ) a = a + 1;

2 раза
a = 6

a = 4; b = 6;
while ( a < b ) a = a + b;

1 раз
a = 10

a = 4; b = 6;
while ( a > b ) a ++;

0 раз
a = 4

a = 4; b = 6;
while ( a < b ) b = a - b;

1 раз
b = -2

a = 4; b = 6;
while ( a < b ) a --;

зацикливание

Слайд 10

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

do
{
}
while ( n <= 0 );

условие продолжения

заголовок

Цикл с постусловием do { } while ( n условие продолжения заголовок
цикла

printf("Введите n > 0: ");
scanf ( "%d", &n );

тело цикла

при входе в цикл условие не проверяется
цикл всегда выполняется хотя бы один раз

Слайд 11

Задачи

«A»: Напишите программу, которая получает два целых числа A и B (0

Задачи «A»: Напишите программу, которая получает два целых числа A и B
< A < B) и выводит квадраты всех натуральных чисел в интервале от A до B.
Пример:
Введите два целых числа:
10 12
10*10=100
11*11=121
12*12=144

«B»: Напишите программу, которая получает два целых числа и находит их произведение, не используя операцию умножения. Учтите, что числа могут быть отрицательными.
Пример:
Введите два числа:
10 -15
10*(-15)=-150

Слайд 12

Задачи

«C»: Ввести натуральное число N и вычислить сумму всех чисел Фибоначчи, меньших

Задачи «C»: Ввести натуральное число N и вычислить сумму всех чисел Фибоначчи,
N. Предусмотрите защиту от ввода отрицательного числа N.
Пример:
Введите число N:
10000
Сумма 17709

Слайд 13

Задачи-2

«A»: Ввести натуральное число и найти сумму его цифр.
Пример:
Введите натуральное число:
12345
Сумма

Задачи-2 «A»: Ввести натуральное число и найти сумму его цифр. Пример: Введите
цифр 15.

«B»: Ввести натуральное число и определить, верно ли, что в его записи есть две одинаковые цифры, стоящие рядом.
Пример:
Введите натуральное число:
12342
Нет.
Пример:
Введите натуральное число:
12245
Да.

Слайд 14

Задачи-2

«C»: Ввести натуральное число и определить, верно ли, что в его записи

Задачи-2 «C»: Ввести натуральное число и определить, верно ли, что в его
есть две одинаковые цифры (не обязательно стоящие рядом).
Пример:
Введите натуральное число:
12342
Да.
Пример:
Введите натуральное число:
12345
Нет.

Слайд 15

Цикл с переменной

Задача. Вывести все степени двойки от 21 до 210.

 
n =

Цикл с переменной Задача. Вывести все степени двойки от 21 до 210.
2;
while ( )
{
printf("%d\n", n);
n *= 2;
}

k = 1;

k <= 10

k ++;

n = 2;
for( )
{
printf("%d\n", n);
n *= 2;
  }

k=1; k<=10; k++

цикл с переменной

Слайд 16

Цикл с переменной: другой шаг

for ( k = 10; k >= 1;

Цикл с переменной: другой шаг for ( k = 10; k >=
k-- )
printf( "%d\n", k*k );

100
81
64
49
36
25
16
9
4
1

for ( k = 1; k <= 10; k += 2 )
printf( "%d\n", k*k );

1
9
25
49
81

Слайд 17

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

a = 1;
for( i = 1; i <= 3;

Сколько раз выполняется цикл? a = 1; for( i = 1; i
i++ ) a = a + 1;

a = 4

a = 1;
for( i = 3; i <= 1; i++ ) a = a + 1;

a = 1

a = 1;
for( i = 1; i <= 3; i-- ) a = a + 1;

a = 1

a = 1;
for( i = 3; i >= 1; i-- ) a = a + 1;

a = 4

Слайд 18

Задачи

«A»: Найдите все пятизначные числа, которые при делении на 133 дают в

Задачи «A»: Найдите все пятизначные числа, которые при делении на 133 дают
остатке 125, а при делении на 134 дают в остатке 111.
«B»: Натуральное число называется числом Армстронга, если сумма цифр числа, возведенных в N-ную степень (где N – количество цифр в числе) равна самому числу. Например, 153 = 13 + 53 + 33. Найдите все трёхзначные Армстронга.

Слайд 19

Задачи

«С»: Натуральное число называется автоморфным, если оно равно последним цифрам своего квадрата.

Задачи «С»: Натуральное число называется автоморфным, если оно равно последним цифрам своего
Например, 252 = 625. Напишите программу, которая получает натуральное число N и выводит на экран все автоморфные числа, не превосходящие N.
Пример:
Введите N:
1000
1*1=1
5*5=25
6*6=36
25*25=625
76*76=5776

Слайд 20

Вложенные циклы

Задача. Вывести все простые числа в диапазоне от 2 до 1000.

сделать для

Вложенные циклы Задача. Вывести все простые числа в диапазоне от 2 до
n от 2 до 1000
если число n простое то
вывод n

число n простое

нет делителей [2.. n-1]: проверка в цикле!

Слайд 21

Вложенные циклы

for ( n = 2; n <= 1000; n ++ )

Вложенные циклы for ( n = 2; n { count = 0;

{
count = 0;
if ( count == 0 )
printf("%d\n", n);
}

for ( k = 2; k < n; k ++ )
if ( n % k == 0 )
count ++;

вложенный цикл

Слайд 22

Вложенные циклы

for ( n = 1; n <= 4; n++ )

Вложенные циклы for ( n = 1; n { for ( k
{
for ( k = 1; k <= i; k++ )
{
...
}
}

n k
1 1
2 1
2 2
3 1
3 2
3 3
4 1
4 2
4 3
4 4

Слайд 23

Поиск простых чисел – как улучшить?

count = 0;
k = 2;
while (

Поиск простых чисел – как улучшить? count = 0; k = 2;
)
{
if ( n % k == 0 ) count ++;
k ++;
}

while( k <= sqrt(n) )
{
...
}

while ( k*k <= n && count == 0 ) {
...
}

k*k <= n

(count == 0)

Слайд 24

Задачи

«A»: Напишите программу, которая получает натуральные числа A и B (A

Задачи «A»: Напишите программу, которая получает натуральные числа A и B (A
выводит все простые числа в интервале от A до B.
Пример:
Введите границы диапазона:
10 20
11 13 17 19
«B»: В магазине продается мастика в ящиках по 15 кг, 17 кг, 21 кг. Как купить ровно 185 кг мастики, не вскрывая ящики? Сколькими способами можно это сделать?
Имя файла: Основы-программирования-(на-языке-Си).-Циклические-алгоритмы.pptx
Количество просмотров: 41
Количество скачиваний: 0