Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 20.11.2020
Сообщений: 1
1

Создать двусвязный циклический список

20.11.2020, 17:57. Показов 1032. Ответов 1
Метки c++ (Все метки)

Author24 — интернет-сервис помощи студентам
Двусвязный циклический список, элемент которого содержит указатель типа void* на элемент данных. Функция включения последним, итераторы foreach и сортировки вставками: (выбирается первый элемент и включается в новый список с сохранением упорядоченности). Проверить на примере элементов данных типов int и float (2 проверки)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
#include <iostream>
#include <clocale>
#include <iomanip>
#include <ctime>
using namespace std;
 
typedef struct _Node {
    void* value;
    struct _Node* next;
    struct _Node* prev;
} Node;
 
 
typedef struct _DblLinkedList {
    size_t size;
    Node* head;
    Node* tail;
} DblLinkedList;
 
DblLinkedList* createDblLinkedList() {
    DblLinkedList* tmp = (DblLinkedList*)malloc(sizeof(DblLinkedList));
    tmp->size = 0;
    tmp->head = tmp->tail = NULL;
 
    return tmp;
}
 
 
void pushFront(DblLinkedList* list, void* data) {
    Node* tmp = (Node*)malloc(sizeof(Node));
    if (tmp == NULL) {
        exit(1);
    }
    tmp->value = data;
    tmp->next = list->head;
    tmp->prev = NULL;
    if (list->head) {
        list->head->prev = tmp;
    }
    list->head = tmp;
 
    if (list->tail == NULL) {
        list->tail = tmp;
    }
    list->size++;
}
 
void* popFront(DblLinkedList* list) {
    Node* prev;
    void* tmp;
    if (list->head == NULL) {
        exit(2);
    }
 
    prev = list->head;
    list->head = list->head->next;
    if (list->head) {
        list->head->prev = NULL;
    }
    if (prev == list->tail) {
        list->tail = NULL;
    }
    tmp = prev->value;
    free(prev);
 
    list->size--;
    return tmp;
}
 
void pushBack(DblLinkedList* list, void* value) {
    Node* tmp = (Node*)malloc(sizeof(Node));
    if (tmp == NULL) {
        exit(3);
    }
    tmp->value = value;
    tmp->next = NULL;
    tmp->prev = list->tail;
    if (list->tail) {
        list->tail->next = tmp;
    }
    list->tail = tmp;
 
    if (list->head == NULL) {
        list->head = tmp;
    }
    list->size++;
}
 
void insertBeforeElement(DblLinkedList* list, Node* elm, void* value) {
    Node* ins = NULL;
    if (elm == NULL) {
        exit(6);
    }
 
    if (!elm->prev) {
        pushFront(list, value);
        return;
    }
    ins = (Node*)malloc(sizeof(Node));
    ins->value = value;
    ins->prev = elm->prev;
    elm->prev->next = ins;
    ins->next = elm;
    elm->prev = ins;
 
    list->size++;
}
 
void insertionSort(DblLinkedList** list, int (*cmp)(void*, void*)) {
    DblLinkedList* out = createDblLinkedList();
    Node* sorted = NULL;
    Node* unsorted = NULL;
 
    pushFront(out, popFront(*list));
 
    unsorted = (*list)->head;
    while (unsorted) {
        sorted = out->head;
        while (sorted && !cmp(unsorted->value, sorted->value)) {
            sorted = sorted->next;
        }
        if (sorted) {
            insertBeforeElement(out, sorted, unsorted->value);
        }
        else {
            pushBack(out, unsorted->value);
        }
        unsorted = unsorted->next;
    }
 
    free(*list);
    *list = out;
}
 
void printDblLinkedList(DblLinkedList* list, void (*fun)(void*)) {
    Node* tmp = list->head;
    while (tmp) {
        fun(tmp->value);
        tmp = tmp->next;
    }
    printf("\n");
}
 
void printInt(void* value) {
    printf("%d ", *((int*)value));
}
 
void printFloat(void* value) {
    printf("%f ", *((float*)value));
}
 
int compareInt(void* a, void* b) {
    //return *(int*)a - *(int*)b;
    if (* (int*)a > * (int*)b)
        return *(int*)a;
    else return *(int*)b;
}
 
int main()
{
    setlocale(LC_ALL, "Russian");
    DblLinkedList* list = createDblLinkedList();
    float o, j, k;   
    int a, b, c, d, e, f, g, h;
    a = -98;
    b = 9;
    c = 3;
    d = -42;
    e = 21;
    f = 129;
    pushFront(list, &c);
    pushBack(list, &d);
    pushFront(list, &b);
    pushFront(list, &a);
    pushBack(list, &e);
    pushBack(list, &f);
    printf("Задаем список: \n");
    printDblLinkedList(list, printInt);
    printf("Вставка сортировок: \n");
    insertionSort(&list, compareInt);
    printDblLinkedList(list, printInt);
}
Попытался сделать таким образом, но ничего не выходит
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.11.2020, 17:57
Ответы с готовыми решениями:

Циклический двусвязный список
Здравствуйте, задали написать програмку: Организовать заданную структуру данных. Определить...

Циклический двусвязный список
Дана последовательность неповторяющихся чисел. Получить 2 последовательности, первая из которых...

Двусвязный циклический список
Необходимо было создать двусвязный циклический список,вот что у меня получилось: #include...

Двусвязный циклический список
помогите исправить ошибки впрограмме не знаю че делать(компилятор dev-c++) заранее спасибо...

1
6579 / 4564 / 1843
Регистрация: 07.05.2019
Сообщений: 13,726
20.11.2020, 19:37 2
Цитата Сообщение от remlik Посмотреть сообщение
Попытался сделать таким образом, но ничего не выходит
В двусвязном циклическом списке указатель на последний элемент, tail, не нужен. На него должен указывать head->prev
0
20.11.2020, 19:37
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.11.2020, 19:37
Помогаю со студенческими работами здесь

Циклический двусвязный список
Помогите написать функцию удаления всех элементов списка с заданным значением. Не могу додуматься...

Двусвязный циклический список - C++
Разработать программу, которая читает с клавиатуры последовательность целых чисел, ни одно из...

Двусвязный циклический список объектов
1. Создать двусвязный циклический список из объектов класса-наследника; 2. Создать функцию,...

Как переделать двусвязный список в циклический c++
Как переделать двусвязный список в циклический c++

Как переделать линейный двусвязный список в циклический?
Нужна помощь с данным двусвязным списком, как переделать его в циклический? #include &quot;stdafx.h&quot;...

Разработать абстрактный тип данных (АТД) «Двусвязный циклический список»
Разработать абстрактный тип данных (АТД) «Двусвязный циклический список». АТД должен обеспечивать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru