Правила записи логических выражений описано в Теме 1.1

Эта конструкция допускает несколько частных вариантов. Простейшее – усеченное разветвление [x] имеет следующий вид:

ifЛогическоеВыражение

Инструкции

End

Напомним, что если ЛогическоеВыражение возвращает логическое значение 1 (то есть «Истина»), выполняются Инструкции, составляющие тело структуры if...end. При этом оператор end указывает на конец перечня инструкций. Инструкции в списке разделяют запятая или точка с запятой. Если ЛогическоеВыражение не выполняется (дает логическое значение 0, «Ложь»), то Инструкции также не выполняются.

Ниже приведен пример использования простейшего усеченного разветвления, реализованного с использования оператора if (рис. 1.3.4-4).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-4. Пример усеченного разветвления

Вторая частная конструкция напоминает стандартное разветвление [x]:

ifЛогическоеВыражение

Инструкции1

Else

Инструкции2

End

Здесь выполняются Инструкции1, если выполняется истинно
ЛогическоеВыражение, или, в противном случае, выполняются
Инструкции2.

В примере, приведенном на рис. 1.3.4-5, рассматривается стандартное разветвление, реализованное с использованием оператора if.

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-5. Пример стандартного разветвления

Из приведенного примера видно, что оператор ifможет быть как в одну строку, так и в несколько строк.

Рассмотрим пример более сложного - вложенного разветвления. Рассмотрим пример

Правила записи логических выражений описано в Теме 1.1 - student2.ru

причем, для того чтобы полностью отразить структуру сложного разветвления, не заботясь о переносе длинных командных строк, используем m-функцию (рис. 1.3.4-7). Подберем данные для проверки основного разветвления и обратимся к функции raz() с различными исходными данными (рис. 1.3.4-6).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-6. Обращение к функции raz()с различными исходными данными

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-7. Функция, реализующая вложенное разветвление

Оператор множественного выбора – switch. Для осуществления множественного выбора используется следующая конструкция switch:

switchBыражение

caseЗачение_1

Список_инструкций_1

caseЗначение_2

Список_инструкций_2

caseЗначение_N

Список_инструкций_N

Otherwise

Список_инструкций_N+1

End

Если выражение после заголовка switch имеет значение одного из выражений Значение..., то выполняется блок операторов case, в противном случае — список инструкций после оператора otherwise. При выполнении блока case исполняются те списки инструкций, для которых Значение совпадает с Bыpaжением. Обратите внимание на то, что Значение может быть числом, константой, переменной, вектором ячеек или даже строчной переменной. Поясним использования оператора перебора switchследующим примером:

Правила записи логических выражений описано в Теме 1.1 - student2.ru Правила записи логических выражений описано в Теме 1.1 - student2.ru

M-функция, реализующая множественное разветвление, приведена на рис. 1.3.4-8, а обращение к ней при исходных данных, позволяющих проверить каждую ветвь разветвления, показано на рис. 1.3.4-9.

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-8. Функция, реализующая множественное разветвление

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-9. Обращения к функции multifunc()

У функции multifunc(x,n) два параметра, причем второй играет роль индикатора, определяющего тип функциональной зависимости. Значение функции записывается в переменную y. Если n=1, то выполняется первый case-блок, если 2, то – второй, если n=2, 3 или 4, то – третий. Если же значение переменной n не совпадает ни с одним из перечисленных значений, то выполняется команда, расположенная после ключевого слова otherwise.

Оператор регулярного цикла – for...end. Оператор цикла типа for...end обычно используется для организации вычислений с заданным числом повторений циклов. Конструкция такого цикла имеет следующий вид:

for vаг = s:d:e

Инструкция1

….

ИнструкцияN

End

где s - начальное значение переменной цикла var, d - приращение этой переменной и е - конечное значение управляющей переменной, при превышении которого цикл завершается. Возможна и запись в виде s:е (в этом случае d=l). Список выполняемых в цикле инструкций завершается оператором end.

В качестве примера использования оператора for...end вычислим сумму элементов массива х, значения которого определены в командном окне с использованием m-функции summa()(рис. 1.3.4-10), параметром которой служит вектор x. Количество элементов массива х определяется функцией length. Кроме обращения к функции в командном окне предусмотрена проверка результата вычислений с использованием встроенной функции sum(x) (рис. 1.3.4-11).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-10. Функция, вычисляющая сумму элементов массива

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-11. Обращение к функции summa() и встроенной функции sum()

В цикле может быть использован оператор continue, который передает управление в следующую итерацию цикла, пропуская операторы, которые записаны за ним, причем во вложенном цикле он передает управление на следующую итерацию основного цикла. Оператор break может использоваться для досрочного прерывания выполнения цикла (например, при отладке участка программы). Как только он встречается в программе, цикл прерывается.

Кроме простых регулярных циклов в Matlab имеется возможность организации вложенных циклов. Рассмотрим пример формирования двумерного массива а, каждый элемент которого представляет сумму его индексов (рис. 1.3.4-12). Обращение к script-файлу vzikl приведено на рис. 1.3.4-13.

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-12. Script-файл, иллюстрирующий вложенные циклы

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-13. Обращение к script-файлу с именем vzikl

Оператор итеративного цикла – while…end. Общий вид структуры while…end выглядит следующим образом:

whileЛогическоеВыражение

Инструкции

End

Отличительной особенностью этой структуры является то, что инструкции, расположенные в теле структуры повторения, выполняются только в том случае, если некоторое ЛогическоеВыражение «истинно». Как только условие становится «ложным», происходит выход из структуры повторения, и управление передается на инструкцию, расположенную после ключевого слова end.

Приведем простой пример (рис. 1.3.4-14).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-14. Диалоговая программа, использующая оператор while…end

Эта программа, сохраненная в m-файле с именем primer11, служит для многократного вычисления длины окружности по вводимому пользователем значению радиуса r, где диалог реализован с помощью команды input.Cтроки, связанные с вводом переменной r и вычислением длины окружности, включены в управляющую структуру while...end. Это необходимо для циклического повторения вычислений при вводе различных значений r. Пока r>=0, цикл повторяется. Но стоит задать r<0, вычисление длины окружности перестает выполняться, а цикл завершается. Поскольку во второй строке программы величинаr определена равной 0, цикл повторяется хотя бы один раз.

Работа с программой в командном окне представлена на рис. 1.3.4-15.

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-15. Обращения к программе вычисления длины окружности

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

Рассмотрим пример досрочного прерывания цикла при выполнении условия i=5 (рис. 1.3.4-16).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-16. Прерывание программы с применением оператора break

Оператор continue передает управление в следующую итерацию цикла, про­пуская операторы, которые записаны за ним, причем во вложенном цикле он пере­дает управление на следующую итерацию основного цикла. Ниже приведен пример вычисления суммы и произведения положительных элементов двумерного массива b(3,3) (рис. 1.3.4-17).

Правила записи логических выражений описано в Теме 1.1 - student2.ru

Рис. 1.3.4-17. Прерывание программы с применением оператора continue

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