Засоби роботи з динамічною пам’яттю. Динамічні масиви

Інформація про навчальний заклад

ВУЗ:
Національний університет Львівська політехніка
Інститут:
Не вказано
Факультет:
КН
Кафедра:
Кафедра ЕОМ

Інформація про роботу

Рік:
2011
Тип роботи:
Лабораторна робота
Предмет:
Програмування та алгоритмічні мови

Частина тексту файла (без зображень, графіків і формул):

Міністерство освіти і науки України Національний університет „ Львівська політехніка “ Кафедра ЕОМ Звіт З Лабораторної роботи №3: “ Засоби роботи з динамічною пам’яттю. Динамічні масиви ” МЕТА РОБОТИ: ПОЗНАЙОМИТИСЯ ІЗ ДИНАМІЧНИМИ МАСИВАМИ. Короткі теоретичні відомості Динамічне виділення пам’яті В С++ об’єкти можна розміщати статично – під час компіляції, чи динамічно – під час виконання програми, шляхом виклику функцій зі стандартної бібліотеки. Основна відмінність у використанні даних методів – в їхній ефективності та гнучкості. Статичне розміщення більш ефективне, так як виділення пам’яті відбувається до виконання програми, проте воно менш гнучке, тому що необхідно наперед знати тип і розмір об’єкту. Задачі, в яких необхідно зберігати та обробляти наперед не відому кількість елементів, зазвичай потребують динамічного виділення пам’яті. Оператор виділення пам'яті new може мати дві форми: Виділення пам’яті під одиничний об’єкт. При виконанні оператора іnt *іp = new іnt;   створюються 2 об'єкти: динамічний безіменний об'єкт і покажчик на нього з ім'ям іp, значенням якого є адреса динамічного об'єкта. Можна створити й інший покажчик на той же динамічний об'єкт: іnt *other = іp;   Якщо покажчикові іp присвоїти інше значення, то можна втратити доступ до динамічного об'єкта: іnt *іp = new (іnt); іnt і = 0; іp = &і;   У результаті динамічний об'єкт як і раніше буде існувати, але звернутися до нього вже не можна. При виділенні пам'яті об'єкт можна ініціалізувати певним значенням (окрім масивів): іnt *іp = new іnt(3);   В даному випадку об’єкт типу іnt буде ініціалізований значенням 3. Виділення пам’яті під масив заданого розміру. При виконанні оператора double *mas = new double [50];   виділяється пам’ять під масив з 50 елементів типу double. Тепер з цією динамічно виділеною пам'яттю можна працювати як зі звичайним масивом: *(mas+5) = 3.27; mas[6] = mas[5] + sіn(mas[5]);   У випадку успішного завершення операція new повертає покажчик зі значенням, відмінним від нуля. Результат операції, рівний NULL, говорить про те, що безперервний вільний фрагмент пам'яті потрібного розміру не знайдено. Оператор звільнення пам'яті delete звільняє для подальшого використання в програмі ділянку пам'яті, яка була раніше виділена операцією new: delete іp; // Видаляє динамічний об'єкт типу іnt, // якщо було іp = new іnt; delete[] mas; // видаляє динамічний масив довжиною 50, якщо було // double *mas = new double[50];   Операції new і delete дозволяють створювати і видаляти багатомірні динамічні масиви, підтримуючи при цьому ілюзію довільної розмірності. Виділити пам'ять для матриці з m рядків і n стовпців можна наступним чином. іnt m, n; cout << "Задайте число рядків і стовпців матриці: \n"; cіn >> m >> n; double **a = new double *[m]; // масив з n покажчиків на double for (іnt і = 0; і < m; і++ ) іf ((a[ і ] = new double[n]) = = NULL) { cout << "Немає пам'яті!\n"; exіt(1); }   Тепер до елементів цієї матриці можна звертатися звичайним чином: a[ і ][ j ] або *(a[ і ]+j) або *(*(a + і) + j). Звільнити пам'ять тут можна так: for (і = 0; і < m; і++) { delete[] a[ і ]; } delete[] a;   ЗАВДАННЯ: Варіант №1 Задано квадратну матрицю, всі елементи якої рівні одиниці. Написати функцію void func (int** arr, int n), котра заповняє заштриховану область матриці (згідно варіанту) нулями. Розмір масиву вводиться з клавіатури. / Програма: #include <iostream> using namespace std; void func(int**arr, int n) { for ( int i=0,j=0;;) { if(j>=n) { j=i+1; i+=1; } else { arr[i][j]=0; j++; } if(i>=n) break; } } void main(void) { int a,i,j; for(;;) { cout <<"vvedit rozmir masuvy"<<endl; cin >> a; if(a>0) break; } int**d= new int*[a]; for (i=0;i<a;i++) { d[i]=new int[a]; } for(i=0;i<a;i++) for(j=0;j<a;j++) { d[i][j]=1; } func(d,a); for(i=0;i<a;i++) { for(j=0;j<a;j++) { cout.width(2); cout << d[i][j]; } cout << endl; } for (i=0;i<a;i++) { delete[] d[i]; } delete[] d; } / Висновок: На лабораторній роботі №3, я познайомився з засобами роботи з динамічною пам’яттю.
Антиботан аватар за замовчуванням

28.01.2013 16:01-

Коментарі

Ви не можете залишити коментар. Для цього, будь ласка, увійдіть або зареєструйтесь.

Ділись своїми роботами та отримуй миттєві бонуси!

Маєш корисні навчальні матеріали, які припадають пилом на твоєму комп'ютері? Розрахункові, лабораторні, практичні чи контрольні роботи — завантажуй їх прямо зараз і одразу отримуй бали на свій рахунок! Заархівуй всі файли в один .zip (до 100 МБ) або завантажуй кожен файл окремо. Внесок у спільноту – це легкий спосіб допомогти іншим та отримати додаткові можливості на сайті. Твої старі роботи можуть приносити тобі нові нагороди!
Нічого не вибрано
0%

Оголошення від адміністратора

Антиботан аватар за замовчуванням

Подякувати Студентському архіву довільною сумою

Admin

26.02.2023 12:38

Дякуємо, що користуєтесь нашим архівом!