Студопедия Главная Случайная страница Обратная связь

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

Лабораторная работа № 4. Составление программ обработки одномерных массивов





 

Цель работы: овладеть практическими навыками работы с одномерными массивами, особенностями их ввода и вывода.

 

Краткие теоретические сведения

Линейным массивом в программе на C++ называется упорядоченный набор однотипных переменных, которые располагаются в памяти последовательно (рисунок 5).

Рис. 5. Одномерный (линейный) массив

Массив является простейшей структурой данных, облегчающей работу с большими объемами информации путем их упорядочения. В случае с массивами, упорядочение происходит за счет индексирования элементов, то есть обращения к каждому из них по порядковому номеру. Показанный на рисунке массив состоит из n элементов с индексами от 0 до n -1, в который записаны числа 5, 21, 0, 12 и т.д.

Любой массив в C++ характеризуется тремя параметрами: именем, типом элементов и размером. Как и обычная переменная, перед использованием массив должен быть объявлен. Общая форма записи объявления:

тип_элементов имя_массива[размер_массива];

Здесь тип_элементов – это любой из известных стандартных типов (int, float, double, char и т.д.), имя_массива – уникальное имя (идентификатор), используемое для обращения к массиву, размер_массива – количество его элементов. В качестве последнего параметра в объявлении может быть использована только целочисленная константа или константное выражение. Примеры объявлений

int A[15]; // массив из 15 целочисленных элементов с именем A

float x[3]; // массив x из 3-х элементов типа float

Объявление массива является командой компилятору на выделение памяти для хранения его элементов. Общее количество выделенной памяти зависит не только от числа элементов, но и от размера каждого элемента, то есть от его типа. Например, текстовая строка из 1000 символов (тип char) займет P = 1000*sizeof(char) = 1000 байтов, а массив из такого же количества вещественных чисел двойной точности (тип double) займет уже в восемь раз больше – P = 1000*sizeof(double) = 8000 байтов.

Нумерация элементов в массиве начинается с нуля. Таким образом, первый элемент массива имеет индекс 0, а последний – индекс n-1, где n – размер массива. Обращение к элементу производится с использованием имени массива и индекса элемента в квадратных скобках. Например, запись “ x[0] = 5.5; ” означает “присвоить значение 5.5 нулевому элементу массива x ”.

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

 

Задание

1. Изучить: способы описания размеров массивов на языке программирования; способы ввода и вывода массивов; реализацию на конкретном языке программирования приемов накопления суммы или произведения, запоминания результатов, нахождения наибольшего и наименьшего.

2. Разработать алгоритм решения в соответствии с заданием.

3. Составить программу решения задачи.

4. Подготовить тест для проверки программы.

Пример выполнения работы

Условие: Напишите программу, запрашивающую у пользователя 10 целых чисел, и выводящую на экран их сумму.

#include < conio.h>

#include < iostream.h>

void main(void)

{

int A[10]; // объявляем массив из 10 целых

for(int i=0; i< 10; i++) // организуем цикл по i от 0 до 9

{

cout < < " input A[" < < i < < " ] = "; // приглашение

cin > > A[i]; // вводим A[i]

}

int sum = 0; // объявляем переменную

for(int i=0; i< 10; i++) // организуем цикл

sum = sum + A[i]; // в цикле суммируем элементы

cout < < " \nSumma: " < < sum; // выводим результат на экран

getch(); // задержка

}

Условие: Дан одномерный массив x[n], где n – размер массива. Найти k– й отрицательный элемент массива.

Начальные данные:

1. константа n, которая определяет размер массива;

2. одномерный массив размерности n;

3. параметр k для порядкового номера отрицательного элемента массива;

4. параметр kn для подсчета числа отрицательных элементов массива;

5. параметр ki для индекса найденного элемента массива.

Результат вычисления: значения параметра kn; значения параметра ki.

#include< iostream.h>

#include< conio.h>

#include< stdlib.h>

void main(void)

{ const n = 10;

int i, a[n];

int k, kn = 0, ki = -1; // kn – для числа отрицательных элементов.

// ki – для индекса текущего отрицательного элемента.

// k – для порядкового номера отрицательного элемента массива.

clrscr();

// Ввод одномерного массива с клавиатуры.

cout < < " Введи элементы массива с клавиатуры: \n";

for (i = 0; i < = n-1; i++) // Начало цикла. Перебор индексов массива.

{

printf(" a[ %d ]= ", i); // Подсказка для пользователя.

scanf(" %d", & a[i]); // Ввод элемента массива с клавиатуры.

}

// Вывод массива на терминал.

clrscr();

cout < < " Введен массив: \n";

for (i = 0; i < = n-1; i++)

printf(" %d ", a[i]);

cout < < " \n";

cout < < " Введи номер для поиска отрицательного элемента k= ";

cin > > k;

// Начало подсчета числа отрицательных элементов в массиве.

for (i = 0; i < = n-1; i++)

{

if (a[i] < 0)

{

kn++; // Если элемент массива отрицательный, значение kn

// увеличиваем на 1.

ki = i; // Запоминаем индекс текущего отрицательного элемента.

if (kn == k)break; // Нашли отрицательный элемент с заданным

// порядковым номером.

}

}

if (kn == k)

cout < < " Элемент a(" < < ki < < ")= " < < a[ki] < < " является " < < kn < < " - ым отрицательным элементом массива \n";

else

cout < < " Отрицательных элементов с порядковым номером " < < k < < " отсутствует\n";

getch(); }

Задания для самостоятельного выполнения

1. Задан одномерный числовой массив. Вычислить среднее арифметическое тех его элементов, значения которых лежат в интервале от 0 до 9.

2. Задан одномерный числовой массив. Заменить все его максимальные элементы числом 100.

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

4. Задан одномерный числовой массив. Верно ли, что количество его положительных элементов не превышает количества его отрицательных элементов?

5. Задан одномерный числовой массив. Заменить последний из его минимальных элементов значением последнего элемента всего массива.

6. Задан одномерный числовой массив, в котором есть хотя бы один нулевой элемент. Какое количество элементов расположено после первого нулевого элемента до конца массива?

7. Задан одномерный числовой массив. Вычислить количество тех его элементов, значения которых совпадают с последним элементом этого массива.

8. Задан одномерный числовой массив. Вычислить сумму тех его элементов, значения которых отличны от значения максимального элемента этого массива.

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

10. Задан одномерный числовой массив. Вычислить сумму тех его элементов, значения которых есть четные числа.

11. Задан одномерный числовой массив. Подсчитать количество максимальных элементов этого массива.

12. Найти сумму всех элементов массива, имеющих четные индексы.

13. Дан массив А, содержащий положительные, отрицательные и нулевые элементы. Из индексов нулевых элементов сформировать новый массив С и найти произведение его элементов.

14. Определить, сколько элементов массива больше, чем число 3 и меньше, чем число -1.

15. Найти сумму элементов массива, превышающих число 8.

16. Найти произведение отрицательных элементов массива.

17. В массиве определить индексы нулевых элементов и заменить нулевые элементы на 5.

18. Дан массив А, содержащий положительные, отрицательные и нулевые элементы. Из отрицательных элементов массива, сформировать новый массив С и найти среднее геометрическое его элементов.

19. Найти разность между наибольшим и наименьшим элементами массива.

Контрольные вопросы

1. Указать особенности программ, использующих массивы.

2. Какие операторы языка можно использовать для описания массивов?

3. В чем состоит особенность организации цикла при обработке массивов?

4. В чем состоит особенность использования приемов программирования при обработке массивов?

5. Указать особенности ввода и вывода массивов.

6. Что представляет собой одномерный массив?

7. Индекс первого элемента массива всегда равен нулю. Верно ли это?

8. Предусмотрена ли в С++ проверка «нерушимости» границ массива?

9. Каждая размерность многомерного массива в С++ заключается в собственную пару квадратных скобок. Верно ли это?

10. Покажите, как объявить двумерный целочисленный массив с именем mas размерностью 10 х 8?

11. Может ли содержать массив переменные нескольких типов?

 

 







Дата добавления: 2014-11-10; просмотров: 4294. Нарушение авторских прав; Мы поможем в написании вашей работы!




Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...


Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...


ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...

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

Влияние первой русской революции 1905-1907 гг. на Казахстан. Революция в России (1905-1907 гг.), дала первый толчок политическому пробуждению трудящихся Казахстана, развитию национально-освободительного рабочего движения против гнета. В Казахстане, находившемся далеко от политических центров Российской империи...

Виды сухожильных швов После выделения культи сухожилия и эвакуации гематомы приступают к восстановлению целостности сухожилия...

Измерение следующих дефектов: ползун, выщербина, неравномерный прокат, равномерный прокат, кольцевая выработка, откол обода колеса, тонкий гребень, протёртость средней части оси Величину проката определяют с помощью вертикального движка 2 сухаря 3 шаблона 1 по кругу катания...

Неисправности автосцепки, с которыми запрещается постановка вагонов в поезд. Причины саморасцепов ЗАПРЕЩАЕТСЯ: постановка в поезда и следование в них вагонов, у которых автосцепное устройство имеет хотя бы одну из следующих неисправностей: - трещину в корпусе автосцепки, излом деталей механизма...

Понятие метода в психологии. Классификация методов психологии и их характеристика Метод – это путь, способ познания, посредством которого познается предмет науки (С...

Studopedia.info - Студопедия - 2014-2025 год . (0.011 сек.) русская версия | украинская версия