Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции по Си.doc
Скачиваний:
3
Добавлен:
15.11.2019
Размер:
2.72 Mб
Скачать

Int main()

{

int min, max, n, count = 0;

float sred, s = 0.0;

printf(“\nВведите первое число:”);

scanf(“%d”, &n);

if (n==0)

return 0;

min = n; // за минимум и максимум принимаем

max = n; //первое введенное число

count = 1; //введено одно число

s += n;

while (n!=0)

{

printf(“\nВведите очередное число:”);

scanf(“%d”, &n);

if (n==0)

break;

count++;

s += n;

if (n > max)

max = n;

if (n < min)

min = n;

}

printf(“\nСумма = %4.2f”, s);

printf(“\nКоличество чисел = %d”, count);

printf(“\nmin = %d”, min);

printf(“\nmax = %d”, max);

sred = s / count;

printf(“\n Среднее арифметическое = %6.2f”,sred);

return 0;

}

Часто встречающиеся ошибки программирования:

1. Использование после условия точки с запятой, которая, как правило, приводит к появлению бесконечного цикла:

int i=1, s = 0;

while (i<=100);

{

s += i;

i++;

}

2. Условие не заключено в скобки:

int i=1, s = 0;

while i<=100

{

s += i;

i++;

}

3. Отсутствие фигурных скобок, в которые заключается тело цикла:

int i=1, s = 0;

while (i<=100)

s += i;

i++;

Это может привести к появлению бесконечных циклов.

4.Отсутствие в теле цикла оператора, изменяющего условие:

int i=1, s = 0;

while (i<=100)

{

s += i;

}

Это тоже приводит к появлению бесконечных циклов.

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

У циклов с постусловием (циклов типа ДО) проверка условия продолжения цикла производится после выполнения операторов, составляющих тело цикла:

ВЫПОЛНЯТЬ

цепочка

ДО (условие);

Такой цикл повторяется до тех пор, пока условие истинно. Выполнение цикла заканчивается, если операторы цепочки изменяют значения переменных, входящих в условие, и оно становится ложным.

В любом случае этот цикл выполняется хотя бы один раз. Цикл с постусловием превращается в бесконечный, если условие подобрано так, что оно всегда истинно.

Таким образом, условие в данном цикле является условием его продолжения, как и в цикле с предусловием.

В Си цикл с постусловием реализован оператором цикла do:

do

{

оператор;

оператор;

оператор;

. . . . . .

оператор;

}

while (условие);

где do – служебное слово выполнять,

while – служебное слово пока.

Внимание! После слова do точка с запятой не ставится!

Перед закрывающей фигурной скобкой } поставить точку с запятой!

Действия оператора do:

  1. выполняется оператор (цепочка),

  2. проверяется выполнение условия, стоящего после слова while,

  3. если оно истинно, то цикл повторяется,

  4. если условие становится ложным, то цикл заканчивает работу.

Примеры:

  1. вычислить сумму ста первых натуральных чисел:

s = 1 + 2 + 3 + … + 98 + 99 + 100

Пусть s – искомая сумма,

i – очередное число (изменяется от 1 до 100).

Тогда алгоритм решения задачи можно описать следующим образом:

  1. обнуляем сумму s = 0 ,

  2. берем первое число: i = 1,

  3. добавляем в сумму очередное число s = s + i,

  4. как только очередное число станет больше ста, цикл заканчивает работу.

Представим этот алгоритм так:

s = 0;

i = 1;

ВЫПОЛНЯТЬ

s = s + i;

i = i + 1;

ПОКА (i <= 100);

Программа:

#include <stdio.h>

#include <conio.h>

#include <math.h>