Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
lab6.doc
Скачиваний:
14
Добавлен:
09.02.2015
Размер:
57.34 Кб
Скачать

Задача 4.1. Количество элементов между минимумом и максимумом

Написать программу, которая для целочисленного массива из 100 элементов опре­деляет, сколько положительных элементов располагается между его максималь­ным и минимальным элементами.

Запишем алгоритм в самом общем виде.

Определить, где в массиве расположены его максимальный и минимальный эле­менты, то есть найти их индексы.

Просмотреть все элементы, расположенные между ними. Если элемент массива больше нуля, увеличить счетчик элементов на единицу.

Перед написанием программы полезно составить тестовый пример, чтобы более наглядно представить себе алгоритм решения задачи. Ниже представлен пример массива из 10 чисел и обозначены искомые величины:

6 -8 15 9 -1 3 5 -10 12 2

макс + + + мин

Ясно, что порядок расположения элементов в массиве заранее не известен, и сна­чала может следовать как максимальный, так и минимальный элемент, кроме того, они могут и совпадать. Поэтому прежде чем просматривать массив в поисках ко­личества положительных элементов, требуется определить, какой из этих индек­сов больше. Запишем уточненный алгоритм:

1. Определить, где в массиве расположены его максимальный и минимальный элементы:

  • Задать начальные значения для индексов максимального и минимального элементов (например, равные нулю, но можно использовать любые другие значения индекса, не выходящие за границу массива).

  • Просмотреть массив, поочередно сравнивая каждый его элемент с ранее найденными максимумом и минимумом. Если очередной элемент больше ранее найденного максимума, принять этот элемент за новый максимум (т. е. за­помнить его индекс). Если очередной элемент меньше ранее найденного минимума, принять этот элемент за новый минимум.

2. Определить границы просмотра массива для поиска положительных элемен­тов, находящихся между его максимальным и минимальным элементами:

  • Если максимум расположен в массиве раньше, чем минимум, принять левую границу просмотра равной индексу максимума, иначе — индексу минимума.

  • Если максимум расположен в массиве раньше, чем минимум, принять правую границу просмотра равной индексу минимума, иначе — индексу максимума.

3. Обнулить счетчик положительных элементов. Просмотреть массив в указанном диапазоне. Если очередной элемент больше нуля, увеличить счетчик на единицу.

Для экономии времени при отладке значения элементов массива задаются путем инициализации.

#include <iostream >

using namespace std;

int main()

{

setlocale(0,”rus”);

const int n = 10;

int a[n] = { 6, 15, 9,-1, 3, 5,-10, 12, 2}; // данные контрольного примера

int i, imax, imin, count;

for (i = imax = imin =0; i < n; i++)

{ if (a[i] > a [imax]) imax = i;

if (a[i] < a[imin]) imin = i;

}

cout <<"\n\t max= "<< a[imax]<< " min= "<< a[imin]; // отладка

int ibeg = imax < imin ? imax : imin;

int iend = imax < imin ? imin : imax;

cout <<"\n\t ibeg= "<< ibeg <<" iend= " << iend; // отладка

for (count = 0, i = ibeg + 1; i < iend; i++)

if (a[i] > 0) count++;

cout << " Количество положительных " << count << endl;

return 0;

}

В программе использована управляющая последовательность \t, которая задает отступ при выводе на следующую позицию табуляции.

СОВЕТ

После нахождения каждой величины вставлена отладочная печать. Ни­когда не пренебрегайте этим способом отладки и не жалейте времени, стараясь сделать эту печать хорошо читаемой, то есть содержащей необходимые пояснения и хорошо отформа­тированной. Это экономит много времени при отладке программы.

Массив просматривается, начиная с элемента, следующего за максимальным (мини­мальным), до элемента, предшествующего минимальному (максимальному). Ин­дексы границ просмотра хранятся в переменных ibeg и iend. В приведенной выше программе для определения их значений используется тернарная условная опера­ция (см. с. 36). Можно поступить и по-другому; просматривать массив всегда от максимума к минимуму, а индекс при просмотре увеличивать или уменьшать в зависимости от их взаимного расположения.

Тестовых примеров для этой задачи должно быть по крайней мере три для случа­ев, когда:

а [ imin ] расположен левее а [ imax];

a[imin] расположен правее a[imax];

a[imin] и a[imax] совпадают.

Последняя ситуация имеет место, когда в массиве все элементы имеют одно и то же значение. Желательно также проверить, как работает программа, если a[imin] и a[imax] расположены рядом, а также в начале и в конце массива (граничные случаи). Элементы массива нужно задавать как положительные, так и отрицательные.

Часто бывает, что точное количество элементов в исходном массиве не задано, но известно, что оно не может превышать некое конкретное значение. В этом случае память под массив выделяется «по максимуму», а затем заполняется только часть этой памяти. Память можно выделить либо с помощью оператора описания в сте­ке или сегменте данных, либо в динамической области. Фактическое количество введенных элементов запоминается в переменной, которая затем участвует в орга­низации циклов по массиву, задавая его верхнюю границу. Этот подход является весьма распространенным, поэтому мы приводим ниже небольшую, но полезную программу, в которой выполняется только считывание элементов массива с кла­виатуры и их вывод на экран:

#include <iostream.h>

int main(){

const int n = 1000;

int a[n];

int i, kol_a;

cout<< "Введите количество элементов ";

cin >> kol_a;

if (kol_a > n ) {

cout <<" Превышение размеров массива "<< endl;

return 1;

}

for (i = 0; i < kol_a; i++) cin >> a[i];

for (i = 0; i < kol_a; i++) cout << a[i] << " ";

cout << endl;

return 0;

}

Несмотря на то, что значение константы n определяется «с запасом», надо обяза­тельно проверять, не запрашивается ли большее количество элементов, чем воз­можно. Привычка к проверке подобных, казалось бы, маловероятных случаев по­зволит вам создавать более надежные программы, а нет ничего более важного для программы, чем надежность.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]