4283

Работа с массивами в языке С++

Лабораторная работа

Информатика, кибернетика и программирование

Работа с массивами в языке С++ 1 Цель работы Получение практических навыков в работе с массивами. В ходе выполнения работы необходимо создать программу, которая определяет и инициализирует двумерный массив целых значений и затем выполняет след...

Украинкский

2012-11-15

70.5 KB

22 чел.

Работа с массивами в языке С++

1 Цель работы 

Получение практических навыков в работе с массивами.

В ходе выполнения работы необходимо создать программу, которая определяет и инициализирует двумерный массив целых значений и затем выполняет следующие действия:

  •  чтение данных с консоли;
  •  преобразование исходного массива в соответствии с шагом один из индивидуального задания;
  •  создание и заполнение нового (одномерного) массива типа double  элементами, полученными в соответствии с шагом два из индивидуального задания;
  •  вывод результатов (оба массива).

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

При создании одномерного динамического массива используется оператор new и удаляется он перед концом программы с помощью оператора delete.

Таблица 1.1 – Индивидуальные задания

Номер студента в списке

Преобразование исходного массива (шаг один)

Заполнение нового массива преобразованными элементами исходного массива (шаг два). Результир. массив должен содержать:

Количество строк m

Количество столбцов n

1

Удвоить нечетные элементы

Квадратные корни минимальных положительных элементов строк

4

3

2

Четные элементы заменить их квадратами

Кубические корни минимальных элементов столбцов

3

5

3

Нулевые элементы заменить на единицы

Натуральные логарифмы максимальных положительных элементов строк

3

4

4

Удвоить четные элементы

Натуральные логарифмы минимальных положительных элементов столбцов

4

5

5

Все элементы заменить на их модули

Минимальные элементы столбцов

5

4

6

Утроить четные элементы

Кубические корни диагональных элементов

3

3


7

Все положительные элементы заменить их десятичные логарифмы

Суммы отрицательных элементов столбцов

4

5

8

Все отрицательные элементы заменить на их квадраты

Квадратные корни диагональных элементов

4

4

9

Все положительные элементы заменить на их натуральные логарифмы

Произведение отрицательных элементов строк

5

4

10

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

Максимальные положительные элементы строк

3

5

11

Удвоить положительные четные элементы

Кубические корни максимальных элементов столбцов

5

4

12

Утроить отрицательные нечетные элементы

Квадратные корни минимальных положительных элементов столбцов

3

4

13

Удвоить отрицательные нечетные элементы

Сумму десятичных логарифмов положительных элементов строк

4

3

14

Утроить положительные четные элементы

Частное от деления максимальных положительных элементов столбцов на их десятичные логарифмы

3

5

Чтобы использовать стандартные математические функции вам необходимо подключить заголовочный файл cmath. В таблице 1.2  представлены некоторые используемые функции.

Таблица 1.2 – Используемые функции

double sqrt(double x);

Берет квадратный корень положительного числа

double pow(double x, double y);

Возводит x в степень y

double log(double x);

Вычисляет натуральный логарифм

double log10(double x);

Вычисляет десятичный логарифм.

int abs(int x);

Возвращает модуль целого числа

double fabs(double x);

Возвращает модуль вещественного числа

double sin(double x);

Вычисляет синус числа

double cos(double x);

Вычисляет косинус числа

double atan(double x);

Вычисляет тангенс числа

2 Теоретические сведения

2.1Массивы

Массивы относятся к так называемым сложным, или составным типам данных. Массив - это структура данных, состоящая из элементов одного типа. В отличие от других структур данных (например, списков), элементы массивов всегда последовательно расположены в памяти.

При объявлении массива после идентификатора в квадратных скобках задается константа (в частности именованная или константное выражение) - число элементов массива:

int a[5];        // Массив из пяти элементов типа int

const int n = 5;

double a1[n];    // Массив из пяти элементов типа double 

Число элементов массива нельзя задавать переменной или неконстантным выражением. Массив может инициализироваться списком значений в фигурных скобках:

int b[4] = {1, 2, 3, 4};

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

int c[] = {1, 2, 3}; // Массив из трех элементов типа int 

Если размерность массива больше числа значений в списке, то не инициализированные явно элементы массива будут установлены в 0 (значение по умолчанию). Если размерность массива меньше числа значений в списке, возникнет ошибка компиляции.

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

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

2.2 Многомерные массивы

Массивы с размерностью 2 и более рассматриваются как массивы массивов и для каждого измерения указывается число элементов:

double aa[2][2] = {1, 2, 3, 4}; // Матрица 2 * 2

То же самое, но более наглядно:

double aa[2][2] = {{1, 2},

                  {3, 4}};

Первая размерность - это размерность по строкам, а вторая - по столбцам. При инициализации списка значений вторая и последующие размерности должны указываться явно.

Для индексирования в многомерном массиве требуется пара скобок для каждого измерения:

int i = 0, j = 1;

aa[i][j] = i + j;

Элементы многомерных массивов в памяти выстраиваются в одномерную структуру (массив), в которой в начале стоят элементы первой строки, потом второй и т.д.

3 Порядок выполнения работы

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

2. Разработать программу для решения поставленной задачи (использовать условные операторы и операторы цикла).

3. Проверить работоспособность программы на тестовых данных.

4. Сохранить результаты работы. Оформить отчет по лабораторной работе.

Содержание отчета:

  1.  Титульный лист.
  2.  Название лабораторной работы.
  3.  Цель лабораторной работы.
  4.  Ход выполнения работы (включить алгоритм решения задачи; программный код; пример использования программы).
  5.  Выводы по проделанной работе c описанием ошибок, с которыми Вы столкнулись при выполнении лабораторной работы.


 

А также другие работы, которые могут Вас заинтересовать

78950. Этические проблемы науки 20 века 42.5 KB
  Этические проблемы науки 20 века. Этика науки Этика науки изучает нравственные основы научной деятельности.Этические проблемы науки начала ХХ1в. Этические проблемы науки рождались в связи с развитием физики биологии в частности генетики психологии.
78951. Правовое регулирование научной деятельности 38 KB
  Правовое регулирование научной деятельности Одним из фундаментальных вопросов современного общества является вопрос об отношении к интеллектуальному труду правовому механизму использования результатов такого труда и регулирования возникающих при этом правоотношений. Правовые аспекты интеллектуальной деятельности лежат в плоскости решения проблем распределения прав на ее результаты с необходимостью охраны и защиты интеллектуальных достижений. Продуктом умственной деятельности оказывается знание. №982 Об использовании результатов...
78952. Философия техники (фт), ее генезис, предмет и задачи 47 KB
  Философия техники фт ее генезис предмет и задачи. Проблема возникновения техники с разделением труда была поставлена Гегелем. Он показал важную роль техники в возникновении капитализма показал разрушительное воздействие машинного производства на человека.Ленк назвал Маркса первым философом техники.
78953. Становление, развитие и специфика технических наук 56.5 KB
  Становление развитие и специфика технических наук. Техника большую часть своей истории была мало связана с наукой; люди могли делать и делали устройства не понимая почему они так работают. Инженеры провозглашая ориентацию на науку в своей непосредственной практической деятельности руководствовались ею незначительно. После многих веков такой автономии наука и техника соединились в XVII веке в начале научной революции.
78954. Сущность и природа техники 47.5 KB
  Сущность и природа техники. Существует 5 основных подходов сущности техники. отношением: Техника и бытие Техника и человек Техника и природа Техника и социокультурный мир Техника и Бог Даются следующие трактовки техники: Онтологическая Хайдеггер. Это характерно для создания техники ремесленным трудом не преминим к современной технике.
78955. Технология и ее связь с техникой 47 KB
  Впервые термин «технология» появился в 70-х годах 18 века в Западной Европе. Если техники – «это», то технология – «как это сделано». Если техника – способ, то технология – способ способа. Если техника – есть ставшее, то технология – способ становления, если техника- способ преобразования мира, то технология – организация использование чел. этих средств. Если техника – артефакт, то технология – метод создания артефактов и учения о нем.
78956. Природа и техника, законы их функционирования и развития 59 KB
  Природа и техника законы их функционирования и развития. Закон необходимое существенное устойчивое повторяющееся отношение связь между явлениями в природе и обществе. Это понятие закона родственно понятию сущности при данных условиях. Закономерность объективно существующая повторяющая существенная связь явлений проявляющаяся в виде тенденций.
78957. Инновации в традиционном и техногенном обществах 29.5 KB
  Инновации в традиционном и техногенном обществах Традиционные общества является исторически первыми. Данный тип общества возник в глубокой древности распространен он и сейчас. Некоторые традиционные общества были поглощены техногенными другие приобрели гибридные черты балансируя между техногенными и традиционными ориентациями. При характеристике традиционных типов общества очевиден тот факт что они обладая замедленным темпом развития придерживаются устойчивых стереотипов своего функционирования.
78958. Ценности классической, неклассической, постнеклассической науки 39.5 KB
  Существуют социальные и внутренние ценности. Социальные ценности делятся на материальные и духовные. удовлетворение своих материальных потребностей научные ценности истина добро зло итд Социальные ценности: частная собственность рыночная экономика деньги итд социальнополитические: свобода слова собраний критики различные права эстетические и философские ценности Внутри научные 1. Социальные и внутринаучные ценности диалектически связаны между собой.