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

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

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

Рік:
2006
Тип роботи:
Звіт
Предмет:
Програмування
Група:
КІ-14

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

Міністерство освіти і науки України Національний університет „Львівська політехніка” Кафедра ЕОМ Звіт з лабораторної роботи № 3 з програмування Тема: Структура даних „СТЕК” Мета роботи: Побудувати структуру даних “cтек” і дослідити динаміку вмісту стеку. Teoритичні відомості: Стеком називається впорядкований набір елементів у якому розміщення нових елементів і визначення існуючих виконується тільки з одного його кінця, який називається вершиною стеку. Завдання: Реалізуйте зв’язаний стек, у якому до опису стеку додана ще одна змінна EMPTY. Перепишіть основні операції роботи зі стеком і продемонструйте динаміку вмісту стеку. Програма: // інтерфес #include <stdio.h> #include <stdlib.h> #include <malloc.h> #include <conio.h> #define infotype int #define printfspec "%d" struct node { infotype data; struct node *next; }new_node; typedef struct node *stack; void Init(stack *stack_top_ptr); int Empty(stack stack_top); void Push(stack *stack_top_ptr, infotype new_data); infotype Pop(stack *stack_top_ptr); void Print(stack stack_top); void main() { stack L2; infotype EMPTY; struct node a={6,NULL},b={1,&a},c={2,&b},*L1=&c; printf("pochatkovyiu steck;\n"); Print (L1); printf("Vvedit element jakyiy dodaty;\n"); scanf("%d",&EMPTY); Push (&L1,EMPTY); printf("pochatkovyiu steck (+) now_element;\n"); Print (L1); EMPTY=Pop (&L1); printf("pochatkovyiu steck (-) 1_element;\n"); Print (L1); Init(&L2); Push (&L2,EMPTY); printf("inshyiu steck;\n"); Print (L2); } // ініціалізація void Init(stack *stack_top_ptr) { *stack_top_ptr = NULL; return; } //перевірка чи стек порожній int Empty(stack stack_top) { return stack_top == NULL; } // додаваня в стек void Push(stack *stack_top_ptr, infotype new_data) { new_node.data = new_data; new_node.next = *stack_top_ptr; *stack_top_ptr = &new_node; return; } //вилучення зі стеку infotype Pop(stack *stack_top_ptr) { stack del_node; infotype del_data; if (Empty(*stack_top_ptr)) { printf(" Error : Stack is empty!\n"); return 0; } else { del_node = *stack_top_ptr; del_data = (*stack_top_ptr)->data; *stack_top_ptr = (*stack_top_ptr)->next; return del_data; }; } // роз друк стеку void Print(stack stack_top) { void PrintReverse(stack stack_top); printf("Elements of stack: "); if (Empty(stack_top)) printf("Stack is empty! \n"); else { PrintReverse(stack_top); printf("\n"); } return; } void PrintReverse(stack stack_top) { if (stack_top) { PrintReverse(stack_top->next); printf(printfspec,stack_top->data); } return; } Результати: Pochatkovyiu stack; Elements of stack; 612 Vvedit element jakyiu dodaty; 4 Pochatkovyiu stack <+> now_element; Elements of stack; 6124 Pochatkovyiu stack < - > 1_element; Elements of stack; 612 Inshyiu stack; Elements of stack; 4 Висновок: На дані лабораторні роботі ми навчилися будувати стек і відстежили динаміку змін вмісту стеку.
Антиботан аватар за замовчуванням

01.01.1970 03:01-

Коментарі

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

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

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

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

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

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

Admin

26.02.2023 12:38

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