Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
 Аватар для MeteoR174
0 / 0 / 0
Регистрация: 24.11.2016
Сообщений: 33

Сортировка двусвязного списка, по мере поступления информации

24.04.2017, 20:11. Показов 1427. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите отсортировать двусвязный список следующим образом: "элементы добавлять таким образом, чтобы сохранялась упорядоченность списка по номерам групп (вставка нового элемента после элемента, который меньше нового элемента и перед большим элементом), путем манипуляции с указателями звеньев списка!" Я уже совсем запутался в этих указателях, уже бред пишу. (Условие: никакого ООП и готовых решений, список нужно создать самостоятельно) С созданием, добавлением, удалением элементов никаких проблем не возникает, даже с сортировкой (если обменивать данные, а не указатели), а вот сортировка по указателям это для меня оказалось через чур трудным, хотя наверняка решение простое.
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
struct Aeroflot
{
    char* name;
    int num;
};
struct List
{
    Aeroflot data;
    List *next;
    List *prev;
};
 
List *head = NULL;
List *last = NULL;
 
 
//сортировка по полю num
void Add_Sort(char *name, int num)
{
    List *tmp = new List;
 
    tmp->data.name = new char[strlen(name) + 1];
    strcpy(tmp->data.name, name);
    tmp->data.num = num;
 
//вот здесь я поплыл совсем
    if (head == NULL)
    {
        head = tmp;
        last = tmp;
        tmp->prev = NULL;
        tmp->next = NULL;
    }
    else
    {
        List *last1 = last;
        while (last1->data.num > tmp->data.num)
        {
            if (last1->prev == NULL)
            {
                tmp->next = last1;
                tmp->prev = last1->prev;
                head = tmp;
                last1->prev = tmp;
                break;
            }
                tmp->next = last1;
                tmp->prev = last1->prev;
                last1->next = tmp->next;
 
                last1->prev = tmp;
        }
        
            tmp->prev = last;
            last->next = tmp;
            last = tmp;
            tmp->next = NULL;
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
24.04.2017, 20:11
Ответы с готовыми решениями:

"Сортировка двусвязного списка путем исключения элемента с минимальным значением и включения его в начало нового списка
Здравствуйте! Возникла проблема с программой. Тема: "Сортировка двусвязного списка путем исключения элемента с минимальным значением и...

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

Сортировка двусвязного списка
Имеется список двусвязный кольцевой: class List { class Entry { public int m_value; public Entry m_next; public...

1
 Аватар для igorrr37
2874 / 2021 / 991
Регистрация: 21.12.2010
Сообщений: 3,759
Записей в блоге: 9
24.04.2017, 20:51
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
#include <iostream>
 
struct Aeroflot
{
    char* name;
    int num;
};
 
struct List
{
    Aeroflot data;
    List *next;
    List *prev;
};
 
List *head = NULL;
List *tail = NULL;
 
 
//сортировка по полю num
void Add(char *name, int num)
{
    List *tmp = new List;
 
    tmp->data.name = new char[strlen(name) + 1];
    strcpy(tmp->data.name, name);
    tmp->data.num = num;
    tmp->next = NULL;
    tmp->prev = NULL;
 
    //вот здесь я поплыл совсем
    if (head == NULL)
    {
        head = tmp;
        tail = tmp;
    }
    else
    {
        List* cur = head;
        while (cur->data.num < tmp->data.num && cur->next)
        {
            cur = cur->next;
        }
        if (cur->data.num >= tmp->data.num)
        {
            if (head == cur)
            {
                tmp->next = head;
                head = tmp;
                tmp->next->prev = tmp;
            }
            else
            {
                tmp->next = cur;
                tmp->prev = cur->prev;
                tmp->prev->next = tmp;
                cur->prev = tmp;
            }
        }
        else
        {
            cur->next = tmp;
            tmp->prev = cur;
            tail = tmp;
        }
    }
}
 
void Print()
{
    for (List* cur = head; cur; cur = cur->next)
    {
        std::cout << cur->data.num << "  ";
    }
    std::cout << std::endl;
}
 
 
int main()
{
    
    Add("", 4);
    Add("", 2);
    Add("", 5);
    Add("", 1);
 
    Print();
 
    return 0;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.04.2017, 20:51
Помогаю со студенческими работами здесь

Сортировка двусвязного списка
Не получается выполнить сортировку двусвязного списка методом пузырька. У меня получилось сделать только один заход, а их надо несколько. ...

Сортировка выбором двусвязного списка
Помогите пожалуйста написать функцию которая сортирует двусвязный список методом выбора Вот двусвязный список: #include &lt;iostream&gt; ...

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

Сортировка двусвязного списка вставками
Добрый день, есть готовый двусвязный список. Нужно было реализовать сортировку вставками любых чисел. В комментариях main() оставил...

Быстрая сортировка двусвязного списка
что не так?? void newsort(Offender_Node*first,Offender_Node*last) { Offender_Node*cur=first,*Prev=cur; ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru