Адміністрація вирішила продати даний сайт. За детальною інформацією звертайтесь за адресою: rozrahu@gmail.com

Застосування АТД

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

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

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

Рік:
2013
Тип роботи:
Звіт про виконання лабораторної роботи
Предмет:
Обчислювальний практикум

Частина тексту файла

Міністерство освіти і науки, молоді та спорту України Національний університет „Львівська політехніка” Кафедра ЕОМ Звіт про виконання лабораторної роботи № 3 з дисципліни: “Обчислювальний практикум” на тему: “ Застосування АТД "Список" до розв’язання прикладних задач” Львів 2013 Мета: Ознайомитись з АТД «Список» Теоретичні відомості: Зв'язаний список в програмуванні — одна з найважливіших структур даних, в якій елементи лінійно впорядковані, але порядок визначається не номерами елементів, а вказівниками, які входять в склад елементів списку та вказують на наступний за даним елемент (в однозв'язаних або однобічно зв'язаних списках) або на наступний та попередній елементи (в двозв'язаних або двобічно зв'язаних списках). Список має «голову» — перший елемент та «хвіст» — останній елемент. Зв'язані списки мають серію переваг порівняно з масивами. Зокрема, в них набагато ефективніше (за час О(1), тобто незалежно від кількості елементів) виконуються процедури додавання та вилучення елементів. Натомість, масиви набагато кращі в операціях, які потребують безпосереднього доступу до кожного елементу, що у випадку зі зв'язаними списками неможливо та потребує послідовного перебору усіх елементів, які передують даному. Однобічно зв'язані списки / Однобічно зв'язаний список з трьох елементів В однобічно зв'язаному списку, який є найпростішим різновидом зв'язаних списків, кожний елемент складається з двох полів: data або даних, та вказівника next на наступний елемент. Якщо вказівник не вказує на інший елемент (інакше: next = NULL), то вважається, що даний елемент — останній в списку. Двобічно зв'язаний список / Двобічно зв'язаний список В двобічно зв'язаному списку елемент складається з трьох полів — вказівника на попередній елемент prev, поля даних data та вказівника next на наступний елемент. Якщо prev=NULL, то в елемента немає попередника (тобто він є «головою» списку), якщо next=NULL, то в нього немає наступника («хвіст» списка). Кільцевий список В кільцевому списку перший та останній елемент зв'язані. Тобто, поле prev голови списка вказує на хвіст списка, а поле next хвоста списка вказує на голову списка. Застосування списків Списки інтенсивно застосовуються в програмуванні як самостійні структури. Також на їх основі можуть будуватись складніші структури даних, такі як дерева. На базі списків також можуть бути реалізовані стеки та черги. Завдання: Многочлен виду ,де  представити у вигляді зв’язаного списку в якому кожний вузол має три поля: одне – для коефіцієнта Сi , друге – для показника степеня ni , третє – для вказівника на наступний вузол списку. Для описаного представлення многочленів програмно реалізувати таку операцію: Множення многочлена на одночлен. Текст програми: Polinomial.h #ifndef _POLYNOMIAL_H_ #define _POLYNOMIAL_H_ #include <list> #include <iostream> using std::list; using std::istream; using std::ostream; using std::ios_base; struct monomial { double coff; int index; }; class polynomial { private: list<monomial> lst; public: polynomial(); ~polynomial(); friend ostream & operator<<(ostream &os, const polynomial &pol); friend istream & operator>>(istream & is, polynomial &pol); polynomial operator*(monomial mon); friend polynomial operator*(monomial mon, const polynomial &pol); }; #endif /* _POLYNOMIAL_H_ */ Main.cpp #include "polynomial.h" using std::cout; using std::endl; using std::cin; int main() { setlocale(0, "Ukr"); polynomial pol; cout << "Введiть многочлен типу (коеф. степiнь). Для завершення введiть 0 для коеф." << endl; cin >> pol; cout << pol << endl; cout << "Введiть одночлен типу (коеф. степiнь): "; monomial mon; cin >> mon.coff; cin >> mon.index; cout << "Результат виразу mon*pol: " << mon*pol << endl; cout << "Результат виразу pol*mon: " << pol*mon << endl; system("pause"); return 0; } Polinomial.cpp #include "polynomial.h" polynomial::polynomial() { } polynomial::~polynomial() { } ostream & operator<<(ostream &os, const polynomial &pol) { ...
Антиботан аватар за замовчуванням

03.04.2018 21:04

Коментарі

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

Завантаження файлу

Якщо Ви маєте на своєму комп'ютері файли, пов'язані з навчанням( розрахункові, лабораторні, практичні, контрольні роботи та інше...), і Вам не шкода ними поділитись - то скористайтесь формою для завантаження файлу, попередньо заархівувавши все в архів .rar або .zip розміром до 100мб, і до нього невдовзі отримають доступ студенти всієї України! Ви отримаєте грошову винагороду в кінці місяця, якщо станете одним з трьох переможців!
Стань активним учасником руху antibotan!
Поділись актуальною інформацією,
і отримай привілеї у користуванні архівом! Детальніше

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

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

пропонує роботу

Admin

26.02.2019 12:38

Привіт усім учасникам нашого порталу! Хороші новини - з‘явилась можливість кожному заробити на своїх знаннях та вміннях. Тепер Ви можете продавати свої роботи на сайті заробляючи кошти, рейтинг і довіру користувачів. Потрібно завантажити роботу, вказати ціну і додати один інформативний скріншот з деякими частинами виконаних завдань. Навіть одна якісна і всім необхідна робота може продатися сотні разів. «Головою заробляти» продуктивніше ніж руками! :-)

Новини