12083

Робота з динамічною памяттю

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

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

Тема. Робота з динамічною пам’яттю Мета. Навчитися виділяти місце під об’єкти динамічно. Навчитися створювати та використовувати конструктор копіювання перевантажувати оператор присвоєння. Ознайомитися з принципами створення та функціонування деструкторів.

Украинкский

2013-04-24

78.5 KB

10 чел.

Тема. Робота з динамічною пам’яттю 

Мета. Навчитися виділяти місце під об’єкти динамічно. Навчитися створювати та використовувати конструктор копіювання, перевантажувати оператор присвоєння. Ознайомитися з принципами створення та функціонування деструкторів.

Теоретичні відомості.

Завдання для лабораторної роботи

  1.  Створити клас відповідно до завдання (див. Додаток).
  2.  Розробити для класу конструктор за замовчуванням та декілька звичайних конструкторів. Реалізувати функції-члени відповідно до завдання (див. Додаток).
  3.  Створити конструктор копіювання.
  4.  Перевантажити операцію присвоєння.
  5.  Створити деструктор для вивільнення динамічно виділеної пам’яті.
  6.  Продемонструвати розроблені можливості класу завдяки створеному віконному застосуванню.  

Додаток

  1.  Клас Matrix – матриця. Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Знаходження максимального значення матриці.
    •  Знаходження мінімального значення матриці.
    •  Знаходження максимального значення в заданому рядку.
    •  Знаходження мінімального значення в заданому стовпці.
    •  Зміна розмірів матриці.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання
  •  Віднімання
  •  Множення
  •  Множення на скаляр.
  •  Введення матриці з StringGrid (<<)
  •  Виведення матриці у StringGrid(>>)
  •  Виведення матриці у Memo(>>)

Забезпечити можливість отримання значення елементу [i][j] подібно до доступу до елементів звичайного двовимірного масиву.

  1.  Клас Array – одновимірний масив. Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Знаходження максимального значення.
    •  Знаходження мінімального значення.
    •  Знаходження середнього арифметичного значення масиву.
    •  Сортування елементів масиву методом вибірки за спаданням.
    •  Сортування елементів масиву методом бульбашки за зростанням.
    •  Зміна розмірів масиву.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (почленне додавання елементів масиву)
  •  Віднімання (почленне віднімання елементів масиву)
  •  Множення на скаляр.
  •  Введення масиву з StringGrid (<<)
  •  Виведення масиву у StringGrid(>>)
  •  Виведення масиву у Memo(>>)

Забезпечити можливість отримання значення елементу [i] подібно до доступу до елементів звичайного одновимірного масиву.

  1.  Клас Mnogyna – множина цілочисельних значень. Пам’ять під елементи множини повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Перевірка на належність елемента множині.
    •  Знаходження потужності множини.
    •  Знаходження максимального значення серед значень множини.
    •  Знаходження мінімального значення серед значень множини.
    •  Додавання елемента до множини.
    •  Видалення елемента з множини.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (об’єднання множин).
  •  Віднімання (перетин множин).
  •  Ділення (різниця множин)
  •  Введення множини з StringGrid (<<)
  •  Виведення множини у StringGrid(>>)
  •  Виведення множини у Memo(>>)
  1.  Клас Strichka – стрічка символів (масив елементів символьного типу). Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Видалення заданого символу із стрічки.
    •  Знаходження кількості входжень заданого символу у стрічку.
    •  Сортування символів стрічки в алфавітному порядку у порядку зростання.
    •  Сортування символів стрічки в алфавітному порядку у порядку спадання.
    •  Вставлення однієї стрічки у іншу з заданої позиції.
    •  Зміна розміру стрічки.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (конкатенація стрічок)
  •  Віднімання (видалення із першої стрічки першого входження другої)
  •  Введення стрічки з StringGrid (<<)
  •  Введення стрічки з Edit (<<)
  •  Виведення стрічки у StringGrid(>>)
  •  Виведення стрічки у Memo(>>)
  •  Виведення стрічки у Edit(>>)
  •  Виведення стрічки у Label(>>)

Забезпечити можливість отримання значення елементу [i] подібно до доступу до елементів звичайного одновимірного масиву.

  1.  Клас Matrix – матриця. Пам’ять під елементи масиву повинна виділятися динамічно. Елементи матриці повинні зберігатися у одновимірному масиві.

Реалізувати такі функції члени:

  •  Знаходження максимального значення матриці.
    •  Знаходження мінімального значення матриці.
    •  Знаходження середнього арифметичного значення матриці.
    •  Зміна розмірів матриці.
    •  Транспонування матриці.
    •  Знаходження оберненої матриці до заданої.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання
  •  Віднімання
  •  Множення
  •  Множення на скаляр.
  •  Введення матриці з StringGrid (<<)
  •  Виведення матриці у StringGrid(>>)
  1.  Клас Matrix – матриця. Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Знаходження максимального значення матриці.
    •  Знаходження середнього арифметичного значення матриці.
    •  Сортування заданого рядка методом вибірки за зростанням.
    •  Сортування заданого стовпця методом вибірки за спаданням.
    •  Зміна розмірів матриці.
    •  Підняття матриці до заданого степеня.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання
  •  Віднімання
  •  Множення
  •  Множення на скаляр.
  •  Введення матриці з StringGrid (<<)
  •  Виведення матриці у StringGrid(>>)
  •  Виведення матриці у Memo(>>)

Забезпечити можливість отримання значення елементу [i][j] подібно до доступу до елементів звичайного двовимірного масиву.

  1.  Клас Array – одновимірний масив. Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Знаходження максимального значення.
    •  Знаходження мінімального значення.
    •  Знаходження мінімального додатного.
    •  Знаходження максимального від’ємного.
    •  Сортування елементів масиву методом бульбашки за зростанням та спаданням.
    •  Зміна розмірів масиву.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (почленне додавання елементів масиву)
  •  Віднімання (почленне віднімання елементів масиву)
  •  Поелементний зсув вліво (- -).
  •  Поелементний зсув вправо (++)
  •  Введення масиву з StringGrid (<<)
  •  Виведення масиву у StringGrid(>>)
  •  Виведення масиву у Memo(>>)

Забезпечити можливість отримання значення елементу [i] подібно до доступу до елементів звичайного одновимірного масиву.

  1.  Клас Mnogyna – множина цілочисельних значень. Пам’ять під елементи множини повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Перевірка на належність елемента множині.
    •  Знаходження потужності множини.
    •  Знаходження максимального від’ємного значення серед значень множини.
    •  Знаходження мінімального додатного значення серед значень множини.
    •  Знаходження максимального за модулем значення.
    •  Додавання елемента до множини.
    •  Видалення елемента з множини.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (об’єднання множин).
  •  Віднімання (перетин множин).
  •  Порівняння множин (==)
  •  Введення множини з StringGrid (<<)
  •  Виведення множини у StringGrid(>>)
  •  Виведення множини у Memo(>>)
  1.  Клас Strichka – стрічка символів (масив елементів символьного типу). Пам’ять під елементи масиву повинна виділятися динамічно.

Реалізувати такі функції члени:

  •  Видалення заданого символу із стрічки.
    •  Заміна всіх входжень одного символу в стрічці заданим символом.
    •  Сортування символів стрічки в алфавітному порядку у порядку зростання.
    •  Вставлення однієї стрічки у іншу з заданої позиції.
    •  Зміна розміру стрічки.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання (конкатенація стрічок)
  •  Порівняння стрічок(< та >) (більшою вважається та, яка йде першою в алфавітному порядку).
  •  Рівність (==)
  •  Введення стрічки з StringGrid (<<)
  •  Введення стрічки з Edit (<<)
  •  Виведення стрічки у StringGrid(>>)
  •  Виведення стрічки у Memo(>>)
  •  Виведення стрічки у Edit(>>)
  •  Виведення стрічки у Label(>>)

Забезпечити можливість отримання значення елементу [i] подібно до доступу до елементів звичайного одновимірного масиву.

  1.  Клас Matrix – матриця. Пам’ять під елементи масиву повинна виділятися динамічно. Елементи матриці повинні зберігатися у одновимірному масиві.

Реалізувати такі функції члени:

  •  Знаходження максимального від’ємного значення матриці.
    •  Знаходження мінімального додатного значення матриці.
    •  Знаходження максимального за модулем значення матриці.
    •  Зміна розмірів матриці.
    •  Транспонування матриці.
    •  Обертання матриці.

Перевантажити операції. При цьому вибір механізму перевантаження обрати самостійно (чи метод, чи дружня-функція):

  •  Додавання
  •  Віднімання
  •  Множення
  •  Додавання до матриці одиничної (++)
  •  Введення матриці з StringGrid (<<)
  •  Виведення матриці у StringGrid(>>)


 

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

43626. Влияние применения ближнего света фар в дневное время суток на безопасность дорожного движения 1.99 MB
  В разделе «Введение» изучается значение станций технического обслуживания, необходимость их планирования, приводится описание станций технического обслуживания, видов СТО и производимых на них работах и услугах. Раздел «Технологический расчет»: представляет собой расчет производственной программы, годового объема работ, количества постов, численности рабочих и площадей помещений производственного корпуса.
43627. Анализ и оптимизация САР частоты вращения вала двигателя постоянного тока 2.54 MB
  Даля кафедра автоматизации и компьютерноинтегрированных технологий Курсовой проект по дисциплине Теория автоматического управления на тему: анализ и оптимизация САР частоты вращения вала двигателя постоянного тока В №13.2 Описание принципа действия САР 1.3 Определение передаточных функций элементов САР 1.4 Построение модели структурной схемы САР 1.
43628. УПРАВЛЕНИЕ ПЕРСОНАЛОМ Т.В. Зайцева, А.Т. Зуб 2.12 MB
  В учебнике рассматриваются важнейшие вопросы теории и практики управления персоналом организации: история становления данной науки; принципы, методы и подходы к построению системы управления персоналом в организации; основные процессы. Проанализированы различные аспекты основных направлений деятельности в рамках управления персоналом: планирование потребности в персонале и найм, оценка результативности труда, мотивация и оплата труда персонала...
43629. Организация проведения ТО и ТР автомобилей УАЗ -31512 в условиях ОАО Ростелеком г. Ухта 1.04 MB
  Транспорт важнейший элемент инфраструктуры, под который понимают отрасли народного хозяйства, создающие общие его функционирования. Транспорт оказывает активное влияние на процесс расширенного воспроизводства, величину запасов, сырья, топлива и промышленной продукции, производственную мощность складов
43630. НАБОР КОРПУСА СУДНА 3.04 MB
  Определить плавучесть остойчивость непотопляемость можно вычислив гидростатические и гидродинамические силы и моменты действующие на смоченную поверхность судна в различных условиях эксплуатации. Значение направление и точки приложения этих сил зависят от формы корпуса судна которая может быть описана графически при помощи теоретического чертежа. Теоретический чертеж изображает поверхность корпуса металлического судна без наружной обшивки. Проекции корпуса судна на эти плоскости соответственно носят названия: Бок Полуширота и...
43631. АУДИТ УЧЕТА ТРУДА И ЗАРАБОТНОЙ ПЛАТЫ В ОТРАСЛИ ЖИВОТНОВОДСТВА В СПК «БОЛЬШЕУТИНСКИЙ» 290.97 KB
  Целью дипломной работы является исследование организации бухгалтерского учета оплаты труда, анализ учета труда и заработной платы работников животноводства на примере СПК «Большеутинский». В соответствии с поставленной целью нами были сформулированы следующие задачи:
43632. Графічне представлення даних за допомогою діаграм MS Excel 968.33 KB
  Візуалізація даних за допомогою діаграм Microsoft Excel дозволяє забезпечити наочне подання даних й істотно полегшити їх інтерпретацію при складанні звітів, підготовці презентацій, аналізі великих обсягів числових даних.
43634. КУЛЬТУРОЛОГИЯ И.Г. Малкова 627.5 KB
  Понятие культура, по крайней мере, трехаспектное. Культура - это 1) система материальных и духовных ценностей человечества; 2) деятельность человека по созданию этих ценностей; 3) потребление этих ценностей, означающих изменение, развитие человека, усвоение того социокультурного опыта, который был накоплен предшествующими поколениями.