Динамические структуры данных
Проблемы с организацией данных. Определение и классификация динамических структур данных. Линейные односвязные, двухсвязные, кольцевые списки. Очередь, стеки. Описание основных типов данных и функции для работы с ними. Листинг программы, пример ее работы.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | контрольная работа |
Язык | русский |
Дата добавления | 17.07.2012 |
Размер файла | 290,6 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
22
Размещено на http://www.allbest.ru/
Динамические структуры данных
Содержание
динамическая структура данное
- 1.Условие задания
- 2.Динамические структуры данных
- 2.1 Проблемы с организацией данных
- 2.2 Определение и классификация динамических структур данных
- 2.3 Линейный односвязный список
- 2.4 Двухсвязные линейные списки
- 2.5 Кольцевой список
- 2.6 Очередь
- 3.Стеки
- 4.Описание основных типов данных и функции для работы с ними
- 5.Листинг программы
- 6.Пример работы программы
- Литература
1.Условие задания
Гаражная стоянка имеет одну стояночную полосу, причем въезд и выезд находятся в одном конце полосы. Если владелец автомашины приходит забрать свой автомобиль, который не является ближайшим к выходу, то все автомашины, загораживающие проезд, удаляются, машина данного владельца выводится со стоянки, а другие машины возвращаются на стоянку в исходном порядке.
Написать программу, которая моделирует процесс прибытия и отъезда машин. Прибытие или отъезд автомашины задается командной строкой, которая содержит признак прибытия или отъезда и номер машины. Программа должна выводить сообщение при прибытии или выезде любой машины. При выезде автомашины со стоянки сообщение должно содержать число раз, которое машина удалялась со стоянки для обеспечения выезда других автомобилей.
2.Динамические структуры данных
2.1 Проблемы с организацией данных
При разработке программ во многих случаях достаточно использовать простые переменные и массивы. Память под такие объекты выделяется либо на этапе компиляции, либо на этапе выполнения программы. Приведём фрагменты программ, показывающие оба эти способа на примере выделения памяти под одномерный массив:
а) Память выделена на этапе компиляции:
const int N = 5;
int x1[N];
б) Память выделена на этапе исполнения программы с помощью операции new:
int *x2;
int n;
do{
cout << "n=";
cin >> n;
}while(n <= 0);
x2 = new int[n];
Теперь массивы x1 и x2 можно использовать, например, задать значения элементам этих массивов.
Но в обоих случаях после того, как память под массивы выделена, мы не можем изменять размеры этих массивов по своему усмотрению. Если быть более точным, то это справедливо только для случая а). Для варианта б) проблему решить можно. Но какой ценой?! Приведём возможную программную реализацию изменения размера динамического массива:
//пусть k -- новый размер массива
int k = n + 1;
// выделяем новый участок памяти необходимого размера
int *t = new int[k];
// переписываем в него содержимое исходного массива x2
for(int i = 0; i < k && i < n; i++)
t[i] = x2[i];
// освобождаем память, на которую указывал x2
delete []x2;
// настраиваем x2 на новый участок памяти
x2 = t;
Как не сложно понять, такой подход к решению проблемы будет занимать слишком много машинного времени. В общем-то неразумно выделять заново память под целый массив, когда нам требовался дополнительный участок всего для одного элемента.
2.2 Определение и классификация динамических структур данных
Для того, чтобы в процессе выполнения программы произвольно добавлять и удалять данные, необходимо организовать наши данные не в массив, а в нечто другое. Если к элементу данных добавить ещё и указатель, в котором будет храниться адрес какого-то другого элемента, то это и будет кардинальным решением проблемы. Такая организация представления и хранения данных называется динамической структурой данных.
Каждый элемент динамических структур данных состоит из собственно данных и одного или нескольких указателей, ссылающихся на аналогичные элементы. Это позволяет добавлять в динамическую структуру новые данные или удалять какие-то из имеющихся, не затрагивая при этом другие элементы структуры.
Кроме того, динамические структуры позволяют нам организовать данные так, чтобы их представление в программе было максимально приближено к тому, как эти данные выглядят в реальности. Так, для моделирования обслуживания очереди к кассе в магазине лучше всего подойдет динамическая структура данных под названием «очередь», а не пресловутый массив, а для представления сети автомобильных дорог массив вообще неприемлем. Здесь нужна именно «сеть».
Динамические структуры данных бывают линейные и нелинейные. В линейной динамической структуре данные связываются в цепочку. К линейным структурам относятся списки (односвязные, двухсвязные, кольцевые), стеки, очереди (односторонние, двухсторонние, очереди с приоритетами). Организация нелинейных структур более сложная. Нелинейные структуры представляются, как правило, в виде дерева (каждый элемент имеет некоторое количество связей, например, в бинарном дереве каждый элемент (узел) имеет ссылку на левый и правый элемент).
Рассмотрим более подробно некоторые виды динамических структур.
2.3 Линейный односвязный список
Линейный список -- это динамическая структура данных, каждый элемент которой посредством указателя связывается со следующим элементом.
Графически линейный список можно представить следующим образом:
Более подробно этот вид рассмотрим в 3 части.
2.4 Двухсвязные линейные списки
Как мы уже говорили, линейные списки могут быть односвязными и двухсвязными.
Каждый элемент односвязного списка кроме собственно данных содержит поле с адресом следующего элемента. Работу с такими списками мы только что рассмотрели.
В двухсвязном списке каждый элемент имеет поля с данными и два указателя: один указатель хранит адрес предшествующего элемента списка, второй -- адрес последующего элемента. Вполне естественно для работы с двухсвязным списком использовать два указателя, хранящие адреса начала и конца такого списка. На рисунке ниже даётся графическое представление двухсвязного списка.
2.5 Кольцевой список
Кольцевой список -- это список, у которого последний элемент связан с первым. Кольцевой список можно сделать как односвязным, так и двухсвязным. Рассмотрим вкратце односвязный кольцевой список.
Схема кольцевого списка представлена на рисунке ниже (используем те же данные, что и для ранее рассмотренного односвязного списка, т.е. список из чисел 3, 5, 1, 9):
2.6 Очередь
Очередь -- это линейная динамическая структура данных, для которой выполняется правило: добавление новых данных возможно только в конец этой структуры, а удаление (извлечение) -- только с начала. В англоязычной литературе этот принцип называется FIFO (First Input -- First Output, т.е. первый пришёл -- первый ушёл).
Примером из реальной жизни может быть очередь из покупателей к кассе в магазине.
Как не трудно понять, очередь -- это линейный список, для которого определены всего две основные операции: добавление в конец и извлечение с начала. Значит, удобно иметь два указателя: на начало и конец этой динамической структуры. Но списки бывают односвязные и двухсвязные. Какой использовать? Подойдёт только двухсвязный список. В этом можно будет убедиться при рассмотрении основных алгоритмов для работы с очередью.
На рисунке ниже показано графическое представление очереди. Как и в предыдущих темах, очередь будем строить из целых чисел, например: 3, 5, 1.
Всё это не так сложно реализовать самостоятельно, поэтому ни каких программных примеров не приводится.
3.Стеки
Определение стека
Стек -- динамическая структура данных, для которой выполняется правило: последним пришёл -- первым ушёл. Таким образом, и дополнение новых данных, и извлечение их из стека всегда выполняется с одной стороны.
Вершина стека -- эта та его часть, через которую ведётся вся работа. На вершину стека добавляются новые элементы, и с вершины стека снимаются (удаляются) элементы.
В общем, стек -- это односвязный список, для которого определены только две операции: добавление и удаление из начала списка.
Примером стека может служить коробка, в которую сверху укладывают книги. Извлекать книги также приходится сверху.
Операции со стеком
Рассмотрим основные и дополнительные действия со стеком. Для работы используем структуры Data и Stek:
struct Data
{
int a;
};
struct Stek
{
Data d;
Stek *next;
};
В программе определяем указатель на начало будущего стека:
Stek *u = NULL;
После этого можно начать работать со стеком.
1. Добавление в стек. Функцию добавления назовём Push() -- по аналогии с командой ассемблера push, которая заносит целое число в программный стек.
void Push(Stek **u, Data &x)
{
Stek *t = new Stek; // Память под новый элемент
t->d.a = x.a; // Заполнение полей
t->next = *u; // Подключаем новый элемент к имеющимся
*u = t; // Перенастройка вершины
}
Обратиться к функции можно так:
Push(&u,x);
где x -- объект типа Data.
2. Извлечение из стека. Здесь снова аналогия с ассемблером (команда pop выталкивает целое число из стека).
bool Pop(Stek **u, Data &x)
{
if(*u == NULL)
{
cout << "Pustoj stek" << endl;
return false;
}
Stek *t = *u;
x.a = t->d.a; // Получаем значения полей на вершине стека
*u = t->next; // Перенастройка вершины
delete t; // Удаление ненужного элемента
return true;
}
Пример вызова функции:
Data y;
if(Pop(&u, x))
{
y = x;
cout << "y=" << y.a << endl;
}
Дополнительные действия со стеком -- распечатка стека (можно взять алгоритм для работы с односвязным списком) и чтение с вершины стека. Чтение напоминает извлечение, но при этом данные из стека не удаляются. Вот возможный вариант реализации:
bool Read(Stek **u, Data &x)
{
if(*u == NULL)
{
cout << "Pustoj stek" << endl;
return false;
}
Stek *t = *u;
x.a = t->d.a; // Заполнение полей
return true;
}
Использование функции Read() может быть аналогичным использованию Pop().
4.Описание основных типов данных и функции для работы с ними
Для организации хранения, представления данных в программе используются 2 структуры: Avto и Stek.
Структура Avto необходима для описания всех полей, которые характеризуют один автомобиль в гараже. Она имеет следующий вид:
struct Avto
{
char marka[10];
};
Структура Stek необходима для организации стека. Она имеет следующий вид:
struct Stek
{
Avto a;
Stek *next;
};
где
· a -- поле типа Avto, в котором хранятся сами данные;
· *next -- указатель на стек того же типа, то есть Stek.
Для работы со стеками в программе реализованы все необходимые методы:
· void vvod(Avto &x) -- ввод данных
· void Print(Stek *u) -- функция печати
· void dobavlenie(Stek **u, Avto &x) -- добавление новой записи в стек
· bool Zabiraem(Stek**u, Avto &x) -- функция удаление элемента из стека
· void vyezjaet_iz_garaja(Stek**u) -- функция выезда автомобиля из гаража
· void Clear(Stek **u) -- очистка всего стека
5.Листинг программы
#include <iostream>
#include <windows.h>
#include <string.h>
using namespace std;
HANDLE hConsole=GetStdHandle(STD_OUTPUT_HANDLE);
struct Avto
{
char marka[10];
};
struct Stek
{
Avto a;
Stek *next;
};
char bufer [255];
char*rus (char*s)
{
CharToOem (s,bufer);
return bufer;
}
void vvod(Avto &x)
{
cin>>x.marka;
}
void Print(Stek *u)
{
int k=0;
Stek *p = u;
if(p==0)
{
cout<<rus("\nВ Гараже НЕТ машин!!!")<<endl;
return;
}
while(p)
{
p->a.marka;
p = p->next;
k++;
}
cout<<rus("\n\tВ гараже "); if(k<5) cout<<k<<rus(" машины")<<endl;
else cout<<k<<rus(" машин")<<endl;
p = u;
SetConsoleTextAttribute(hConsole, 11);
cout<<rus("\n ГАРАЖ:")<<endl;
while(p)
{
cout<<"\t* ";
cout << p->a.marka<<endl;
p = p->next;
}
cout<<"\t********"<<endl;
SetConsoleTextAttribute(hConsole, 7);
}
void dobavlenie(Stek **u, Avto &x)
{
Stek *t=new Stek;
strcpy(t->a.marka,x.marka);
t->next=*u;
*u=t;
}
bool Zabiraem(Stek**u, Avto &x)
{
if(*u==NULL){
return false;
}
Stek*t=*u;
strcpy(x.marka, t->a.marka);
*u=t->next;
delete t;
return true;
}
void vyezjaet_iz_garaja(Stek**u)
{
Stek *v=NULL;
Avto x;
char n[7];
cout<< rus("\n\t Введите машину, которая выезжает:");
cin>>n;
while(*u)
{
if(Zabiraem(u,x))
{
if(strcmp(n, x.marka)==0)
{
cout<< rus(" машина ") << n; cout<<rus(" уехала!!!");
while(Zabiraem(&v, x)) /// возвращаем элементы из стека V в стек U
dobavlenie(u, x);
return;
}
else
{
dobavlenie(&v, x);
}
}
else break;
}
SetConsoleTextAttribute(hConsole, 12);
cout <<rus(" В гараже НЕТ машины ")<<n<<endl;
SetConsoleTextAttribute(hConsole, 7);
while(Zabiraem(&v,x))
dobavlenie (u,x);
}
void Clear(Stek **u)
{
if(*u == 0) return;
Stek *p = *u;
Stek *t;
while(p)
{
t = p;
p = p->next;
delete t;
}
*u = 0;
}
int main()
{
SetConsoleTextAttribute(hConsole, 10);
cout << "\t***** * ***** * * * *" << endl;
cout << "\t* * * * * * * * * * " << endl;
cout << "\t* * * * * * * *** " << endl;
cout << "\t* ***** ***** ***** *** " << endl;
cout << "\t* * * * * * * * * " << endl;
cout << "\t* * * * * * * * *" << endl;
SetConsoleTextAttribute(hConsole, 7);
cout << "\n" << endl;
Stek *u=NULL;
int n;
Avto x; //переменная x типа avto
do{
SetConsoleTextAttribute(hConsole, 14);
cout<<rus(" ***********************\n * \tМеню:")<<endl;
cout<<rus(" * 1. Приехала новая машина")<<endl;
cout<<rus(" * 2. Печатать гараж")<<endl;
cout<<rus(" * 3. Машина выезжает")<<endl;
cout<<rus(" * 0. Выход")<<endl;
cout<<rus(" ***********************")<<endl;
cout<<rus("\n\tЗадайте действие: ");
cin>>n;
SetConsoleTextAttribute(hConsole, 7);
switch (n)
{
case 1: cout<<rus("Введите новое авто: ");vvod(x);
dobavlenie(&u, x); cout<<rus("\nАвто Добавлено!\a\n"); break;
case 2: Print(u); break;
case 3: Print(u); vyezjaet_iz_garaja(&u); break;
case 0: Clear(&u); break;
default: SetConsoleTextAttribute(hConsole, 12);
cout<<rus("Нет такого ЧИСЛА!!!")<<endl;
SetConsoleTextAttribute(hConsole, 7);
}
cout<<endl;
}while (n!=0);
return 0;
}
6.Пример работы программы
Литература
1. И.Ш. Хабибуллин Программирование C++: Пер. с англ. -- 3-е изд. -- СПб.: БХВ-Петербург, 2006. -- 512 с.
2. Сайт: www.victor192007.narod.ru
3. Конспект лекций по дисциплине «Программирование на языках высокого уровня».
Размещено на Allbest.ru
Подобные документы
Средства создания динамических структур данных. Формат описания ссылочного типа. Структура памяти во время выполнения программы. Линейные списки, стек, очередь. Организация списков в динамической памяти. Пример создания списка в обратном порядке.
лабораторная работа [788,2 K], добавлен 14.06.2009Динамические структуры данных, их классификация и разновидности, назначение и функциональные особенности. Линейные односвязные списки, их внутренняя организация и значение. Порядок и принципы составления программы, главные требования, предъявляемые к ней.
курсовая работа [137,4 K], добавлен 11.05.2014Разработка алгоритмов на динамических структурах данных. Описание структуры данных "стек". Процедуры добавления и удаления элемента, очистки памяти. Код распечатки содержимого всего стека. Инструкция пользователя, код программы, контрольный пример.
курсовая работа [22,9 K], добавлен 19.10.2010Линейные динамические структуры. Построение списочной структуры, состоящей из трехнаправленного и двух однонаправленных списков, связанных между собой. Дерево двоичного поиска для заданного множества целых чисел. Листинг программы на языках Си и Паскаль.
курсовая работа [451,1 K], добавлен 19.10.2013Реализация программы, разработанной в среде Turbo C++. Обработка динамической структуры данных, содержащей сведения об авторах книг. Моделирование работы со структурой как с базой данных. Метод сортировки и описание работы пользовательских подпрограмм.
курсовая работа [124,3 K], добавлен 23.12.2010Определение понятия структур данных. Рассмотрение информации и ее представления в памяти. Особенности непозиционных и позиционных систем счисления. Классификация структур данных, операции над ними. Структурность данных и технология программирования.
презентация [359,3 K], добавлен 20.05.2015Создание базы данных и СУБД. Структура простейшей базы данных. Особенности языка программирования Турбо Паскаль. Описание типов, констант, переменных, процедур и функций. Описание алгоритма базы данных (для сотрудников ГИБДД), листинг программы.
курсовая работа [26,3 K], добавлен 26.01.2012Структура простейшей базы данных и свойства полей. Характеристика типов данных. Описание процесса создания базы данных, таблиц и связей между ними, простых и составных форм, запросов в Microsoft Access. Пример составления подчинённых отчетов и макросов.
курсовая работа [2,9 M], добавлен 14.11.2016Ознакомление с понятием, классификацией и структурными элементами баз данных. Виды моделей данных: иерархическая, сетевая, реляционная. Типы связей. Разработка программы для работы с базами данных в книжном магазине. Действие программы и ее листинг.
курсовая работа [549,3 K], добавлен 22.01.2013Средства выделения и освобождения памяти. Динамические структуры данных. Связные линейные списки и их машинное представление. Структура одно- и двухсвязного списка. Реализация операций над связными линейными списками. Разработка программы на языке С++.
курсовая работа [944,7 K], добавлен 14.03.2015