| netlib.narod.ru | < Назад | Оглавление | Далее > |
Конструкция
if (выражение)
инструкция
else if (выражение)
инструкция
else if (выражение)
инструкция
else if (выражение)
инструкция
else
инструкция
встречается так часто, что о ней стоит поговорить особо. Приведенная последовательность инструкций if — самый общий способ реализации многовариантного выбора. Выражения вычисляются по порядку; как только встречается выражение со значением «истина» (не нуль), выполняется соответствующая ему инструкция; на этом последовательность проверок завершается. Здесь под словом инструкция имеется в виду либо отдельная инструкция, либо группа инструкций в фигурных скобках.
Последняя часть else срабатывает, если не выполняются все предыдущие условия. Иногда в последней части не требуется производить никаких действий, в этом случае фрагмент
else
инструкция
можно опустить или использовать для сообщения об ошибочной ситуации.
В качестве иллюстрации трехвариантного выбора рассмотрим функцию бинарного поиска значения x в массиве v. Предполагается, что элементы массива v упорядочены по возрастанию. Функция возвращает позицию числа x в массиве v (число в пределах от 0 до n-1), если x там встречается, и -1, если его нет.
При бинарном поиске значение x сначала сравнивается с элементом, находящимся в середине массива v. Если x меньше, чем это значение, то областью поиска становится «верхняя» половина массива v, в противном случае — «нижняя». В любом случае следующий шаг — это сравнение со средним элементом отобранной половины. Процесс «уполовинивания» диапазона продолжается ло тех пор, пока либо не будет найдено значение, либо не станет пустым диапазон поиска. Запишем функцию бинарного поиска:
/* binsearch: Найти x в массиве v. Массив должен быть
упорядочен по возрастанию. */
int binsearch (int x, int v[], int n)
{
int low, high, mid;
low = 0;
high = n - 1;
while (low <= high) {
mid = (low + high) / 2;
if (x < v[mid])
high = mid - 1;
else if (x > v[mid])
low = mid + 1;
else
return mid; /* совпадение найдено */
}
return -1; /* совпадений нет */
}
Основное действие, выполняемое на каждом шаге поиска, — сравнение значения x (меньше, больше или равно) с элемнтом v[mid]; это сравнение и выполняется конструкцией else-if.
| Упражнение 3-1 |
В нашей программе бинарного поиска внутри цикла осуществляются две проверки, хотя могла быть только одна (при увеличении числа проверок вне цикла). Напишите программу, предусмотрев в ней одну проверку внутри цикла. Оцените разницу во времени выполнения. |
| netlib.narod.ru | < Назад | Оглавление | Далее > |