Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
3 / 3 / 4
Регистрация: 27.10.2014
Сообщений: 51

Сортировка однонаправленного списка (метод пузырька)

29.03.2018, 22:26. Показов 1999. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написал программу однонаправленного списка записей со следующей структурой: ФИО, место жительства, марка авто, год выпуска.
Помогите сделать сортировку списка по годам (методом пузырька, связь между элементами списка).
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
#include <iostream>
#include <stdio.h>
#include <conio.h>
#include <string.h>
#include <cstdlib>
#define WINDOWS 1
 
void clrscr() {
  #ifdef WINDOWS
  system("cls");
  #endif
  #ifdef LINUX
  system("clear");
  #endif
}
using namespace std;
 
 
 
struct avto
{
    char fam[30];
    char ms[30];
    char marka[9];
    int year;
    avto* next;
};
 
typedef avto* ptr;
ptr headptr;
 
void vvod(avto &av)
{
    printf("  "); scanf("%s", &av.fam);
    printf("  "); scanf("%s", &av.ms);
    printf("  "); scanf("%s", &av.marka);
    printf("  "); scanf("%d", &av.year);
}
 
int formspisok()
{
    ptr p;
    char let;
    headptr=NULL;
    do
    {
        printf("Vvod:\n");
        let=getch();
        if(let=='n') return 1;
        if(headptr==NULL)
        {
            headptr=new avto;
            p=headptr;
        }
        else
        {
            p->next=new avto;
            p=p->next;
        };
        vvod(*p);
        p->next=NULL;
    }while (1);
}
 
void pech(avto av)
{
   // printf("%14s,%20%s,%6s,%6d",av.fam,av.ms,av.marka,av.year);
    cout<<av.fam<<" "<<av.ms<<" "<<av.marka<<" "<<av.year;
}
 
void pechspisok()
{
    ptr p;
    p=headptr;
    while (p!=NULL)
    {
        pech (*p);
        p=p->next;
    }
}
//сортировка по году выпуска
/*int sort()
{
    
    return 0;
}*/
 
int main()
{
    clrscr();
    formspisok();
    printf("Spisok\n");
    pechspisok();
    //sort();
    //printf("Sort Spisok\n");
    //pechspisok();
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.03.2018, 22:26
Ответы с готовыми решениями:

Сортировка однонаправленного списка
Доброго времени суток, уважаемые форумчане! Возникла проблема с сортировкой однонаправленного списка методом &quot;пузырька&quot;. Что...

Сортировка однонаправленного списка
Все работает как надо, кроме функции сортировки. Нужно отсортировать так, чтобы в списке сначала шли журналы, затем газеты. Интовую дату...

Сортировка однонаправленного списка записей
Написать программу сортировки однонаправленного списка записей со следующей структурой: Структура: Фамилия, место жительства, марка...

7
475 / 427 / 290
Регистрация: 10.03.2015
Сообщений: 1,782
30.03.2018, 00:22
Могу привести один из вариантов реализации сортировки, но "сортировка списка" здесь, так сказать, условна:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
void Sort(Polynomial **head) {
    Polynomial *node = *head, *foll;
    do {
        foll = node->next;
        while (foll != NULL) {
            if (foll->Power > node->Power)
            {
                Polynomial *temp = new Polynomial;
                temp->Power = foll->Power;
                temp->Factor = foll->Factor;
                foll->Power = node->Power;
                foll->Factor = node->Factor;
                node->Power = temp->Power;
                node->Factor = temp->Factor;
            }
            foll = foll->next;
        }
        node = node->next;
    } while (node->next != NULL);
}
Т.к. основана чисто на перестановке непосредственно самих значений, а не перекидывание связей.
Но для понимания можно использовать, переделав лишь часть замены значений на замену указателей.
0
7 / 7 / 5
Регистрация: 25.03.2018
Сообщений: 377
30.03.2018, 00:24
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
struct COS {
 
    char ObjectName[OBJECT_NAME_LENGTH];
    char Country[COUNTRY_NAME_LENGTH];
    int Square;
 
};
 
typedef struct COS first;
 
for (int gen_count = 1; gen_count <= N; gen_count++) {
 
        for (int sec_count = 0; sec_count <= N - gen_count; sec_count++) {
            // Сортировка по имени стран:
            if (_stricmp(Array_Obj[sec_count].Country, Array_Obj[sec_count + 1].Country) > 0) {
 
                first swap_buf;
 
                swap_buf = Array_Obj[sec_count];
                Array_Obj[sec_count] = Array_Obj[sec_count + 1];
                Array_Obj[sec_count + 1] = swap_buf;
 
            }
            
            else if (_stricmp(Array_Obj[sec_count].Country, Array_Obj[sec_count + 1].Country) == 0) {
                // Сортировка по именам объектов:
                if (strcmp(Array_Obj[sec_count].ObjectName, Array_Obj[sec_count + 1].ObjectName) > 0) {
 
                    first swap_buf;
 
                    swap_buf = Array_Obj[sec_count];
                    Array_Obj[sec_count] = Array_Obj[sec_count + 1];
                    Array_Obj[sec_count + 1] = swap_buf;
 
                }
            }
        }
    }
--------------------------------------------------------------------------------------------------------
Извините, просто лень было в вашей программе разбираться. Вот, как пример, можете посмотреть кусок кода моего ИЗ на 1м курсе
0
475 / 427 / 290
Регистрация: 10.03.2015
Сообщений: 1,782
30.03.2018, 00:29
Цитата Сообщение от cinekst_207 Посмотреть сообщение
Извините, просто лень было в вашей программе разбираться
А где, собственно, список вообще?
0
7 / 7 / 5
Регистрация: 25.03.2018
Сообщений: 377
30.03.2018, 00:59
SuperKir, Такая тема, там нам надо было на хэдэры разделить и поэтому некоторые куски я не скопипастил Сам ввод списка там по циклу for, потом по той фигне, что я выше прислал, сортировка по списку... Или я чего-то не понял, простите, спать хочется просто, в чём именно вопрос? Что значит, где список? Вот, вводим его по структурному типу и потом чекаем сначала имя объекта, а потом страны и при помощи strcmp проверяем коды символов и сортируем их пузырьком

Добавлено через 3 минуты
Но у него надо по годам, поэтому можно просто так писать:
C++
1
2
3
4
5
6
7
8
9
10
// Сортировка по годам:
                if (Array_CSR[sec_count].Year > Array_CSR[sec_count + 1].Year) {
 
                    third swap_buf;
 
                    swap_buf = Array_CSR[sec_count];
                    Array_CSR[sec_count] = Array_CSR[sec_count + 1];
                    Array_CSR[sec_count + 1] = swap_buf;
 
                }
Добавлено через 1 минуту
Ну я думаю автор темы знает как делать массивы структурных типов :3
0
30.03.2018, 01:12

Не по теме:

Цитата Сообщение от cinekst_207 Посмотреть сообщение
Ну я думаю автор темы знает как делать массивы структурных типов :3
Ему нужен не массив, а список :)

0
309 / 221 / 74
Регистрация: 23.05.2011
Сообщений: 981
30.03.2018, 01:34
SuperKir,
Вот тут кто память чистить будет?
C++
1
2
3
4
5
6
7
                Polynomial *temp = new Polynomial;
                temp->Power = foll->Power;
                temp->Factor = foll->Factor;
                foll->Power = node->Power;
                foll->Factor = node->Factor;
                node->Power = temp->Power;
                node->Factor = temp->Factor;
0
475 / 427 / 290
Регистрация: 10.03.2015
Сообщений: 1,782
30.03.2018, 01:44
New man, сборщик мусора
Ну а если откровенно говорить, этой части кода много лет, Ctrl+C / Ctrl+V и я даже не глянул
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
30.03.2018, 01:44
Помогаю со студенческими работами здесь

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

Структуры данных: сортировка однонаправленного списка
значит так, есть вот эта программа: #include &lt;stdio.h&gt; #include &lt;conio.h&gt; #include &lt;math.h&gt; struct spisok { int info; ...

Сортировка списка методом пузырька по убыванию
С сортировкой массивов вроде разобрался.. А вот со списками не выходит, может кто-нибудь помочь? #include &lt;iostream&gt; ...

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

Сортировка массива по возрастанию (метод пузырька) С++
Компилиться хорошо,но есть одна ошибка #include &quot;iostream.h&quot; #include &quot;stdio.h&quot; void bubbleSort(int array, int col){ ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru