Лекции.Орг


Поиск:




Категории:

Астрономия
Биология
География
Другие языки
Интернет
Информатика
История
Культура
Литература
Логика
Математика
Медицина
Механика
Охрана труда
Педагогика
Политика
Право
Психология
Религия
Риторика
Социология
Спорт
Строительство
Технология
Транспорт
Физика
Философия
Финансы
Химия
Экология
Экономика
Электроника

 

 

 

 


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




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

 

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

Инструкции

End

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

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

 

 

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

 

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

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

Инструкции1

Else

Инструкции2

End

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

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

 

 

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

 

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

 

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

 

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

 

 

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

 

 

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

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

switch Bыражение

case Зачение_1

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

case Значение_2

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

case Значение_N

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

Otherwise

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

End

 

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

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

 

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

 

 

Рис. 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.3.4-10. Функция, вычисляющая сумму элементов массива

 

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

 

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

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

 

 

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

 

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

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

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

Инструкции

End

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

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

 

Рис. 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.3.4-15. Обращения к программе вычисления длины окружности

 

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

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

 

 

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

 

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

 

 

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





Поделиться с друзьями:


Дата добавления: 2016-10-30; Мы поможем в написании ваших работ!; просмотров: 731 | Нарушение авторских прав


Поиск на сайте:

Лучшие изречения:

Свобода ничего не стоит, если она не включает в себя свободу ошибаться. © Махатма Ганди
==> читать все изречения...

2338 - | 2092 -


© 2015-2024 lektsii.org - Контакты - Последнее добавление

Ген: 0.01 с.