Створення i ведення лiнiйних спискiв

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

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

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

Рік:
2008
Тип роботи:
Звіт про виконання лабораторної роботи
Предмет:
Теорiя алгоритмiв i математичнi основи представленння знань
Варіант:
1

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

МIНIСТЕРСТВО ОСВIТИ І НАУКИ УКРАЇНИ Національний унiверситет "Львiвська полiтехнiка" Звіт до лабораторної роботи N 1 з курсу "Теорiя алгоритмiв i математичнi основи представленння знань" Створення i ведення лiнiйних спискiв Виконав: ст.гр.КН-23 Прийняв: _________________ Львів 2008 1. МЕТА РОБОТИ Ознайомитися iз способом подання даних в оперативнiй пам’ятi ЕОМ у виглядi лiнiйних спискiв. Оволодiти алгоритмами роботи з послiдовними i зв’язаними лiнiйними списками. 2. КОРОТКІ ТЕОРЕТИЧНI ВIДОМОСТI Необхiдно рацiонально використовувати системнi ресурси, у першу чергу пам’ять. Для правильного застосування пам’ятi важливо розумiти способи подання у нiй даних i методи роботи з ними. У лабораторнiй роботi розглядаються структури даних у виглядi лiнiйних спискiв. Лiнiйний список - це множина, яка складається з n>=0 вузлiв X[1], X[2],, X[n], для якої якщо n>0, то X[1] є першим вузлом; якщо 1<k<n, то k-му вузлу X[k] передує X[k-1] i за ним йде X[k+1]; X[n] є останнiм вузлом. Операцiї, якi можна виконувати з лiнiйним списком: отримати доступ до k-го вузла списку, щоб проаналiзувати i/або змiнити його вмiст; ввести новий вузол безпосередньо перед k-м вузлом; 3) видалити k-вузол; 4) об'єднати кiлька лiнiйних спискiв в один; 5) зробити копiю лiнiйного списку; 6) видалити вузол iз списку; 7) знайти вузол iз заданим значенням у деякому полi. Iснують два методи зберiгання структур даних у пам’ятi комп’ютера. Перший метод розподiлу, який використовує переваги одновимiрної властивостi пам’ятi, називається послiдовним розподiлом. Другий метод розподiлу, що базується на зберiганнi адреси чи розташування кожного елемента списку, вiдомий пiд назвою зв’язаного розподiлу (рис.1). послiдовний розподiл: зв’язаний розподiл: Перший метод не використовується, якщо: 1. Вимоги до пам’ятi є непередбачуваними. 2. Даними, що зберiгаються у пам’ятi, iнтенсивно манiпулюють. Зв’язаний список графiчно можна зобразити у виглядi, показаному на рис.2 NodeType - iм’я типу структури запису, який мiстить ці поля. Використання зв’язаного розподiлу, як правило, передбачає iснування деякого механiзму пошуку вiльного простору для нового вузла, коли ми хочемо ввести у список деяку нову iнформацiю. Для цього необхiдно пiдтримувати пул або список вiльних вузлiв, який називається списком вiльного простору. Пiд час операцiї вставлення вiльний вузол видаляється iз списку вiльного простору i розмiщується у призначений лiнiйний список. I, навпаки, видалений вузол повертається до списку вiльного простору i може бути використаний для наступних вставок. Така схема управлiння пам’яттю має очевиднi переваги - у даний момент використовується простiр пам’ятi, що вiдповiдає фактичному обсяговi даних. Iснують два пiдходи до застосовування списку вiльного простору: пiдтримка списку вiльного простору засобами мови програмування i програмна пiдтримка (застосування пiдтримує власний список вiльної пам’ятi). 3. ІНДИВІДУАЛЬНЕ ЗВДАННЯ Варіант 13 13) Змiнити вмiст k-го вузла #include <iostream.h> #include <conio.h> int k,m; struct nova { int nomer; nova *dali; }; nova *element, *pershij, *poperednij, *novyj, *fix; void stvorspysok(void); void vuvid(void); void ph(void); void main() { clrscr(); cout<<"stvorennja spusky, dlja zakin4ennja -> vvedit' 0\n"; stvorspysok(); cout<<"\n------\n"; vuvid(); cout<<"\nm:\n"; cin>>m; cout<<"\ninfo dlja powyky"; cin>>k; ph(); cout<<"\n"; cout<<"novuj spusok\n"; vuvid(); getch(); } //--------------------------- void stvorspysok(void) { element=new (nova); pershij=element; do { poperednij=element; cin>>element->nomer; element->dali=new (nova); element=element->dali; } while (poperednij->nomer!=0); poperednij->dali=NULL;} //--------------------------- void vuvid(void) { element=pershij; while(element!=NULL) {cout<<element->nomer; element=element->dali;} } //---------------------------- void ph(void) { element=pershij; while(element!=NULL) { if (element->nomer==k) {element->nomer=m;} element=element->dali;}} висновок: при виконанні цієї лабораторної роботи я ознайомився iз способом подання даних в оперативнiй пам’ятi ЕОМ у виглядi лiнiйних спискiв. Оволодiти алгоритмами роботи з послiдовними i зв’язаними лiнiйними списками.
Антиботан аватар за замовчуванням

01.01.1970 03:01-

Коментарі

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

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

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

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

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

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

Admin

26.02.2023 12:38

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