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

Программа:

$count = 0;

$s = 0.0;

echo “<BR>Введите первое число:”;

// ввод $n

if ($n==0)

return 0;

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

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

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

$s += $n;

while ($n != 0)

{

echo “<BR>Введите очередное число:”;

// ввод очередного $n

if ($n == 0)

break;

$count++;

$s += $n;

if ($n > $max)

$max = $n;

if ($n < $min)

$min = $n;

}

echo “<BR>Сумма = $s”;

echo “<BR>Количество чисел = $count”;

echo “<BR>min = $min”;

echo “<BR>max = $max”;

$sred = $s / $count;

echo “<BR>Среднее арифметическое = $sred”;

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

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

$i = 1;

$s = 0;

while ($i <= 100);

{

$s += $i;

$i++;

}

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

$i = 1;

$s = 0;

while $i <= 100

{

$s += $i;

$i++;

}

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

$i = 1;

$s = 0;

while ($i <= 100)

$s += $i;

$i++;

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

$i=1;

$s = 0;

while ($i <= 100)

{

$s += $i;

}

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

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

ВЫПОЛНЯТЬ

цепочка

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

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

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

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

В PHPцикл с постусловием реализован оператором цикла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);

Программа:

$i=1;

$s=0;

do

{

$s += $i;

$i++;

}

while ($i <= 100);

echo “<BR>s = $s i = $i”;

Результат решения задачи:

s = 5050 i = 101

Второй вариант решения задачи:

do

$s += $i++;

while ($i <= 100);

  1. вычислить сумму s всех цифр заданного натурального числа n

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

i – очередная цифра числа.

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

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

  2. берем последнююцифру числа, для чего определяем остаток от деления исходного числа на10:i = n % 10,

  3. добавляем в сумму найденную цифру: s = s + i,

  4. уменьшаем число в 10раз:n = n / 10,

  5. повторяем цикл до тех пор, пока n != 0.

Схема алгоритма:

Программа:

$s = 0;

echo “<BR>Введите целое положительное число:”;

// ввод $n

do

{

$i = $n % 10;

$s += $i;

$n /= 10;

}

while ($n != 0);

echo “<BR>s = $s”;

  1. ввести с клавиатуры по одному последовательность целых чисел (конец последовательности – число 0). Определить их сумму, максимальное и минимальное число, количество введенных чисел и их среднее арифметическое.

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

min, max– минимальное и максимальное из введенных чисел,

count– количество введенных чисел,

sred– среднее арифметическое,

n– очередное число.

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

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

  2. вводим первое число n,

  3. если оно не равно нулю, то

  4. принимаем его значение за minиmax

  5. количество введенных чисел count = 1

  6. увеличиваем сумму на введенное число s = s + n

  7. входим в цикл ввода:

  8. вводим очередное число n,

  9. если оно не равно нулю, то

  10. количество введенных чисел увеличиваем на 1:count = count+1

  11. увеличиваем сумму на введенное число s = s + n

  12. если оно меньше min, тоmin = n,

  13. если оно больше max, тоmax = n,

  14. повторяем цикл до тех пор, пока n # 0– это и будетусловиемпродолжения цикла.

Создадим интерфейсэтой задачи – взаимодействие программы с пользователем, то есть что должно выводиться на экран:

Первое число: 3

Очередное число: 8

Очередное число: 1

Очередное число: -2

Очередное число: 0

Сумма = 10

Количество чисел = 4

min = -2

max = 8

Среднее арифметическое = 2.50