Задание.
Согласно заданию программно объявить класс на языке C++, его методы и поля, написать реализацию этих методов.
В каждом классе должен быть:
- конструктор (задаёт начальные значения полям класса);
- деструктор (освобождает память, которая выделялась под массив);
- метод, резервирующий память под N элементов (N – аргумент);
- метод, задающий значение k-этого элемента массива (k и значение элемента массива – аргументы);
- метод, заполняющий массив случайными элементами;
- метод, выводящий массив на экран;
- метод, описанный в варианте заданий.
В функции main() создать объект этого класса, с его помощью продемонстрировать работу всех методов класса. Вызов каждого метода (кроме конструктора и деструктора) организовать с помощью меню.
При реализации методов класса предусмотреть обработку ошибочных ситуаций: в массиве нет элемента с номером k, k меньше 0 и т.п.
Пример определения класса и работы с его объектом
//файл array.h
Объявление класса
class CDynamicArray
{
//объявление приватных членов класса
//поля класса:
int nCount; //реальная длина массива; если массив пуст – nCount=0
int *arr; // указатель на массив
public: //объеялание общедоступных членов класса
// методы класса::
CDynamicArray(); //конструктор; вызвается, когда создаётся объект класса
~CDynamicArray();//деструктор; вызвается, когда уничтожается объект класса
void CreateArray(int N); //создание массива
void SetValue(int k, int value); //установка элемента массива
void FillArrayRandValues(); //заполнение массива случайными числами
void DisplayArray(); // вывод элементов массива на экран
};
//файл array.cpp
#include "array.h"
#include <stdlib.h>
#include <stdio.h>
реализация методов класса
CDynamicArray::CDynamicArray()
{
nCount=0; //начальные значения полей класса: массив пуст
arr=NULL;
}
CDynamicArray::~CDynamicArray()
{
delete [] arr; //освобождение памяти, занимаемой массивом
}
void CDynamicArray::CreateArray(int N)
{
if (N>0) //если задан корректно новый размер массива – создаём его
{
if (arr!=NULL) //если массив уже существовал – уничтожаем его
delete [] arr;
arr=new int[N];
nCount=N;
printf("Массив создан\n");
}
else
printf("Ошибка! Размер массива должен быть больше 0\n");
}
void CDynamicArray::SetValue(int k, int value)
{
if (k>=0 && k<nCount) //если элемент с индексом k существует, меняем его
arr[k]=value;
else
printf("Ошибка! Задан неверный индекс массива\n");
}
void CDynamicArray::FillArrayRandValues()
{
if(nCount>0) //если массив создан
{
for(int i=0; i<nCount; i++)
arr[i]=rand()%100;
DisplayArray();
}
else
printf("Массив не создан\n");
}
void CDynamicArray::DisplayArray()
{
if(nCount>0) //если массив создан
{
for(int i=0; i<nCount; i++)
printf("%d ",arr[i]);
printf("\n");
}
else
printf("Массив не создан\n");
}
//файл mainfile.cpp
#include "array.h"
#include <stdio.h>
#include <conio.h>
#include <locale.h>
#include <stdlib.h>
#include <time.h>
int main()
{
CDynamicArray ar; //создаётся объект класса, при этом автоматически вызывается конструктор
int key,n,k,val;
srand(time(NULL)); // включаем генератор случайных чисел
setlocale(0,"RUS"); // обеспесиваем вывод в консольное окно символов кириллицы
do
{
printf("\n\n1 - создание массива\n");
printf("2 - изменение элементов массива\n");
printf("3 - заполнение массива случайными числами\n");
printf("4 - вывод на экран элементов массива\n");
printf("ESC - выход\n");
printf("Ваш выбор: \n");
key=getch();
switch(key)
{
case '1':
printf("Введите количество элементов массива: ");
scanf("%d",&n);
ar.CreateArray(n);
break;
case '2':
printf("Введите номер элемента массива: ");
scanf("%d",&k);
printf("Введите значение элемента массива: ");
scanf("%d",&val);
ar.SetValue(k,val);
break;
case '3':
ar.FillArrayRandValues();
break;
case '4':
ar.DisplayArray();
break;
}
}
while(key!=27);
return 0; //объект класса уничтожается, автоматически вызывается деструктор
}
Содержание отчёта
1. Титульный лист.
2. Условие лабораторной работы.
3. Текст программы.
4. Экранные формы с примерами работы программы.
Варианты заданий.
1. Описать класс CArrayDeleteFirstZero для работы с массивами динамической длины. Дополнительный метод: удаление из массива первого найденного нулевого элемента со сдвигом элементов.
2. Описать класс CArraySort для работы с массивами динамической длины. Дополнительный метод: сортировка элементов массива.
3. Описать класс CArrayDelete для работы с массивами динамической длины. Дополнительный метод: удаление элемента с номером N (N – аргумент метода, задаётся пользователем в функции main()).
4. Описать класс CArrayLast для работы с массивами динамической длины. Дополнительный метод: вывод последних N элементов массива (N – аргумент метода, задаётся пользователем в функции main()).
5. Описать класс CArrayDoubleDirected для работы с массивами динамической длины. Дополнительный метод: вывод массива на экран в обратном направлении.
6. Описать класс CArrayRemoveIfOdd для работы с массивами динамической длины. Дополнительный метод: удаление элементов, стоящих на четных местах.
7. Описать класс CArrayRemoveIfOddValue для работы с массивами динамической длины. Дополнительный метод: удаление элементов, четных по значению.
8. Описать класс CArrayRemoveIfNotOdd для работы с массивами динамической длины. Дополнительный метод: удаление элементов, стоящих на нечетных местах.
9. Описать класс CArrayRemoveIfNotOddValue для работы с массивами динамической длины. Дополнительный метод: удаление элементов, нечетных по значению.
10. Описать класс CArrayRemoveEveryN для работы с массивами динамической длины. Дополнительный метод: удаление каждого N-го элемента массива (N – аргумент метода, задаётся пользователем в функции main()).
11. Описать класс CArrayShiftLeft для работы с массивами динамической длины. Дополнительный метод: циклический сдвиг элементов массива влево на N позиций (N – аргумент метода, задаётся пользователем в функции main()).
12. Описать класс CArrayShiftRight для работы с массивами динамической длины. Дополнительный метод: циклический сдвиг элементов массива вправо на N позиций (N – аргумент метода, задаётся пользователем в функции main()).
13. Описать класс CArrayDeleteMaxPositiveItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива максимального положительного элемента со сдвигом элементов.
14. Описать класс CArrayDeleteMaxNegativeItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива максимального отрицательного элемента со сдвигом элементов.
15. Описать класс CArrayDeleteMinPositiveItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива минимального положительного элемента со сдвигом элементов.
16. Описать класс CArrayDeleteMinNegativeItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива минимального отрицательного элемента со сдвигом элементов.
17. Описать класс CArrayDeleteMaxOddItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива максимального чётного элемента со сдвигом элементов.
18. Описать класс CArrayDeleteMaxNotOddItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива максимального нечётного элемента со сдвигом элементов.
19. Описать класс CArrayDeleteMinOddItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива минимального чётного элемента со сдвигом элементов.
20. Описать класс CArrayDeleteMinNotOddItems для работы с массивами динамической длины. Дополнительный метод: удаление из массива минимального нечётного элемента со сдвигом элементов.
21. Описать класс CArrayDeleteFirstOdd для работы с массивами динамической длины. Дополнительный метод: удаление из массива первого найденного чётного элемента со сдвигом элементов.
22. Описать класс CArrayDeleteFirstNotOdd для работы с массивами динамической длины. Дополнительный метод: удаление из массива первого найденного нечётного элемента со сдвигом элементов.
23. Описать класс CArrayDeleteFirstPositive для работы с массивами динамической длины. Дополнительный метод: удаление из массива первого найденного положительного элемента со сдвигом элементов.
24. Описать класс CArrayDeleteFirstNegative для работы с массивами динамической длины. Дополнительный метод: удаление из массива первого найденного отрицательного элемента со сдвигом элементов.
25. Описать класс CArrayDeleteLastOdd для работы с массивами динамической длины. Дополнительный метод: удаление из массива последнего найденного чётного элемента со сдвигом элементов.