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

Двусвязный список сортировка

08.09.2020, 14:06. Показов 355. Ответов 3

Author24 — интернет-сервис помощи студентам
Правильно ли я реализовал сортировку выбором для двусвязного списка?
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
#include <iostream>
using namespace std;
 
struct node
{
    int data;
    node* next;
    node* prev;
    node(void) = default;
    node(int data, node* next = nullptr, node* prev = nullptr);
};
 
node::node(int data, node* next, node* prev) : data(data), next(nullptr), prev(nullptr) {}
 
class list
{
    public: 
    list(void);
    void push_back(const int data);
    void push_front(const int data);
    void sort();
    const size_t size(void) const;
    void print(void) const;
    ~list(void);
    private:
    node* head;
    node* tail;
    size_t _size;
};
 
list::list() : head(nullptr), tail(nullptr), _size(0) {}
const size_t list::size() const
{
    return _size;
}
void list::push_front(const int data)
{
    node* tmp = new(nothrow) node(data);
    if(tmp)
    {
        if(head)
        {
            tmp->next = head;
            head->prev = tmp;
            head = tmp;
        }
        else
        {
            head = tail = tmp;
            head->next = tail;
            head->prev = nullptr;
            tail->next = nullptr;
        }
        ++_size;
    }
}
 
void list::push_back(const int data)
{
    node* tmp = new(nothrow) node(data);
    if(tmp)
    {
        if(head)
        {
            tmp->prev = tail;
            tail->next = tmp;
            tail = tmp;
        }
        else
        {
            head = tail = tmp;
            head->next = tail;
            head->prev = nullptr;
            tail->next = nullptr;
        }
        ++_size;
    }
}
 
void list::sort()
{
    for(auto i = head; i != nullptr; i = i-> next)
    {
        node* tmp = i;
        for(auto j = i->next; j != nullptr; j = j->next)
        {
            if(tmp->data > j->data) tmp = j;
        }
        swap(i->data, tmp->data);
    }
}
 
void list::print() const
{
    node* tmp = head;
    while(tmp)
    {
        cout << tmp->data << " ";
        tmp = tmp->next;
    }
}
 
list::~list()
{
    while(head)
    {
        node* tmp = head->next;
        delete head;
        head = tmp;
    }
    _size = 0;
}
 
int main(void)
{
    list a;
    a.push_front(69);
    a.push_front(169);
    a.push_front(269);
    a.push_front(369);
    a.push_back(1256);
    cout << a.size() << endl;
    a.print();
    a.sort();
    cout << endl;
    a.print();
 
 
 
 
 
 
    
    return EXIT_SUCCESS;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.09.2020, 14:06
Ответы с готовыми решениями:

Двусвязный список. Загрузка, сохранение в файл, сортировка по вводимому параметру
Здравствуйте! Нужна помощь с функцией загрузки информации из файла. Файл создается, информация...

Преобразовать линейный двусвязный список в кольцевой двусвязный
Приветствую. Помогите разобраться как преобразовать линейный двусвязный список в кольцевой...

Переделать двусвязный список в двусвязный кольцевой
Здравствуйте, у меня єсть двусвязный список однако он не кольцевой! как это запрограммировать? и...

Сформировать список из 10 работников, используя динамическую структуру данных двусвязный список
спасайте Сформировать список из 10 работников, используя динамическую структуру данных...

3
6579 / 4564 / 1843
Регистрация: 07.05.2019
Сообщений: 13,726
08.09.2020, 15:51 2
Цитата Сообщение от VladosYetti Посмотреть сообщение
Правильно ли я реализовал сортировку выбором для двусвязного списка?
Вообще, при сортировке списка обычно переставляются не значения элементов, а сами элементы
0
11 / 7 / 4
Регистрация: 27.08.2020
Сообщений: 34
08.09.2020, 16:02  [ТС] 3
oleg-m1973, как можно исправить? swap(i, tmp); так не работает
0
6579 / 4564 / 1843
Регистрация: 07.05.2019
Сообщений: 13,726
08.09.2020, 16:06 4
Цитата Сообщение от VladosYetti Посмотреть сообщение
oleg-m1973, как можно исправить? swap(i, tmp); так не работает
Например вот так Односвязный список. Сортировка по убыванию
0
08.09.2020, 16:06
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.09.2020, 16:06
Помогаю со студенческими работами здесь

Двусвязный список (в конец двусвязного списка добавить другой список)
здравствуйте, подскажите пожалуйста, как в конец двусвязного списка добавить другой список?

Составить двусвязный список на основе класса, объекты которого будут формировать этот список
Составить двусвязный список на основе класса, объекты которого будут формировать этот список. В...

Заменить массив структур на односвязный список, и на двусвязный список
Взять текст задания и заменить массив структур на односвязный список, и на двусвязный список ...

Создать двусвязный список групп факультета, где каждая группа представляет собой односвязный список студентов
Задание: создайте двусвязный список групп факультета. Каждая группа представляет собой односвязный...

Преобразовать односвязный список в двусвязный список
Доброго времени суток! Помогите, пожалуйста, преобразовать программу из односвязного списка в...

Двусвязный список
Привет, народ. Помогите плиз найти ошибку. #include &quot;iostream&quot; #include &quot;cmath&quot; using...


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

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