Разветвляющиеся вычислительные процессы

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

Для вычисления условий используют выражения отношения и логические выражения, результатом выполнения которых являются логические значения Истина или Ложь.

Выражения отношения позволяют сравнивать значения двух выражений для получения булева результата Истина или Ложь. Сравнивать можно числовые выражения (в том числе даты и время), текстовые выражения, логические значения, результаты вычисления функций и формул.

Числовые выражения сравниваются по их значению, а символьные выражения – по кодам входящих в них символов. В табл.1 представлен список операций отношения.

Операции отношения

Операция Действие Операция Действие
= Равно > больше чем
<> не равно >= больше чем
< Меньше чем <= меньше или равно

Определение: выражение отношения - это два выражения одного и того же типа, соединенные знаками операций отношения и результатом выполнения которых будут значения Истина или Ложь.

Логические выражения вместе с выражениями отношения позволяют выполнять сложные проверки, например, выяснить, находится ли некоторое значение в заданном интервале. Для создания логических выражений используются три логические функции И, ИЛИ и НЕ. Функции И и ИЛИ могут иметь до 30 логических аргументов и имеют следующий синтаксис написания:

=И(лог_знач1;лог_знач2;…;лог_знач30)

=ИЛИ(лог_знач1;лог_знач2;…;лог_знач30)

Функция НЕ имеет только один аргумент и имеет следующий синтаксис:

=НЕ(лог_знач).

Аргументы функций И, ИЛИ и НЕ могут быть выражениями отношения, логическими выражениями, массивами, логическими константами или ссылками на ячейки, содержащие логические значения.

Пусть, например, следует решить задачу вычисления значения переменной Y c помощью выражения

разветвляющиеся вычислительные процессы - student2.ru x2, если x >=-0.5 и x <3

Y =

0, если x>=3 или x=-10.

Пример. Пусть значение для переменной Х заносится в ячейку В2, тогда логические выражения для проверки попадания Х в один из двух интервалов имеют вид

=И(В2 >=-0,5;В2 < 3) и =ИЛИ(В2 >= 3;В2 = -10)

Основныеэлементыблок-схем

разветвляющиеся вычислительные процессы - student2.ruНачало и конец блок-схемы

разветвляющиеся вычислительные процессы - student2.ru Ввод - вывод данных

разветвляющиеся вычислительные процессы - student2.ru Оператор присваивания

разветвляющиеся вычислительные процессы - student2.ru Оператор ветвления

разветвляющиеся вычислительные процессы - student2.ru Оператор цикла

Использование блок-схемы для записи разветвляющихся вычислительных процессов

Пример 1. Вычислить значение Y: разветвляющиеся вычислительные процессы - student2.ru

разветвляющиеся вычислительные процессы - student2.ru

См. блок-схему.

Для реализации этой управляющей структуры в Excel имеется функция ЕСЛИ, которая имеет следующий синтаксис:

=ЕСЛИ(лог_выр;знач_если_истина;знач_если_ложь)

Всего можно использовать до семи вложений функций ЕСЛИ (это справедливо для всех функций), но при этом нельзя выходить за пределы максимальной длины значения в ячейке (255 символов). Это ограничивает возможности Excel при решении подобных задач, но для практических задач вполне достаточно.

Для уменьшения длины формулы можно организовать блок констант, в котором разместить текстовые сообщения. Это позволяет заменить соответствующие текстовые константы ссылками на соответствующие ячейки.

разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru

Вывод «Функция не задана»
разветвляющиеся вычислительные процессы - student2.ru
У=0
разветвляющиеся вычислительные процессы - student2.ru
Вывод у
разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru
Вывод у
разветвляющиеся вычислительные процессы - student2.ru разветвляющиеся вычислительные процессы - student2.ru Реализация в Excel:

разветвляющиеся вычислительные процессы - student2.ru

Иногда у функции необходимо проверить область определения:

Функция Область определения

разветвляющиеся вычислительные процессы - student2.ru g(x)≠0

разветвляющиеся вычислительные процессы - student2.ru , где n – четное число f(x)≥0

Logaf(x) f(x)>0

Arcsin(f(x)) -1 ≤ x ≤ 1

Arccos(f(x)) -1 ≤ x ≤ 1

Пример 2. Вычислить значение функции Y:

разветвляющиеся вычислительные процессы - student2.ru

Сначала нарисуем интервалы и блок-схему.

разветвляющиеся вычислительные процессы - student2.ru

Реализация в Excel:

разветвляющиеся вычислительные процессы - student2.ru

Наши рекомендации