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

"Сортировка двусвязного списка путем исключения элемента с минимальным значением и включения его в начало нового списка

04.05.2014, 19:29. Показов 4533. Ответов 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
#include "stdafx.h"
#include <stdio.h> 
#include <stdlib.h> //подключаем библиотеку содержащую стандартные функции ввода-вывода
 
struct elem                 //объявляем элемент списка    
{
    int value;              //value-значение, хранящееся в элементе списка 
    elem *next,*pred;       //*next и *pred - указатели на следующий и предыдущий элементы списка(список двусвязный)
};
 
 
int _tmain(int argc, _TCHAR* argv[])    
{
    elem *in_h=NULL, *in_e=NULL, *out_h=NULL,*q,*min, *q_pred, *q_next;
    int m;
    puts("Vvedite koli4estvo elementov v sodavaemom spiske");   
    scanf("%d",&m);
    for(int i=0;i<m;i++)    
    {
        printf("num %d : ",i);
 
        q=new elem;                 //создание нового элемента спискаб выделение под него динамич памяти
        scanf("%d",&(q->value));    //заполнение его значением
        if(in_h==NULL)              //если список пуст
        {
            q->pred=NULL;
            q->next=NULL;
            in_h=q;
            in_e=q;
        }
        else                        //если в списке уже что было
        {
            q->pred=in_e;
            q->next=NULL;
            in_e->next=q;
            in_e=q;
        }
 
    }
 
if(in_h!=NULL)                              //если список не пуст, то начнем обработку
{
    while(in_h->next!=NULL)             //до тех пор пока не останется 1 элемент в исходном списке
    {
        min=in_h;                       //далее отыскание минимума
        q=min->next;
        do
        {
            if((q->value)<(min->value))
            {
                min=q;
            }
            q=q->next;
        }while(q!=NULL);            //минимум ищется до конца списка...
 
        if((min->pred!=NULL)&&(min->next!=NULL))        //если минимальный элемент в списке не первый и не последнии
        {
            (min->pred)->next=min->next;                //вырезаем его
            (min->next)->pred=min->pred;
        }
        else
        {
            if(min->pred==NULL)             //если первый
            {
                in_h=min->next;             //вырезаем его
                in_h->pred=NULL;
            }
            else
            {                                   //ну и если последний
                (min->pred)->next=NULL;         //вырезаем его
            }
        }
                                //далее вставляем в начало нового списка
        if(out_h==NULL)         //  если новый список еще пуст    
        {
            min->pred=NULL;         //то вставим таким образом
            min->next=NULL;
            out_h=min;
        }
        else                //если в новом списке уже есть элементы 
        {
            min->pred=NULL;     //то вставим таким образом
            min->next=out_h;
            out_h=min;
        }
 
    }
 
        in_h->pred=NULL;        //ну и перенесем последний оставшийся элемент
        in_h->next=out_h;
        out_h=in_h;
 
    q=out_h;                    //пробежим по всему новому списку и выведем на экран значения
    do
    {
     printf("%d ",q->value);
     q=q->next;
    }while(q!=NULL);
 
 q=out_h->next;//пробегаем по всем элементам списка и очищаем выделенную под них память
     do
     {
      delete q->pred;
      q=q->next;
     }while(q!=NULL);
}
else                        //а если if(in_h!=NULL)    не выполнилось, то есть список пуст, то ниче не пытаемся сделать
    puts("Spisok pust");    //и выдаем что список пуст
 
 
    scanf("%d ",&m);            //что б окошко сразу не исчезло
        return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.05.2014, 19:29
Ответы с готовыми решениями:

Сортировка двусвязного списка путем исключения элемента с минимальным значением и включения его в начало нового списка.
Как удалить найденный минимальный элемент из исходного списка??????????????? #include &quot;stdafx.h&quot; #include...

Работа с деками. Найти среднее арифметическое списка, добавить его в качестве нового элемента в начало и конец списка
D - список действительных чисел. Найти среднее арифметическое списка, добавить его в качестве нового элемента в начало и конец списка. ...

Переместить в начало линейного списка элемент с минимальным значением
обьясните пож что делается в молих заданиях напишите по русски не паскалевским языком но чтобы мне было понятно 4. Переместить в...

2
0 / 0 / 0
Регистрация: 16.03.2013
Сообщений: 61
06.05.2014, 19:23  [ТС]
/delete
0
1 / 1 / 0
Регистрация: 15.09.2014
Сообщений: 10
01.11.2014, 19:21
Подскажите, пожалуйста, как вы все-таки решили проблему?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.11.2014, 19:21
Помогаю со студенческими работами здесь

Создание списка, печать списка на экран, добавления элемента в начало списка, конец списка
Построить динамическую структуру типа список . Необходимо реализовать следующие процедуры: 1. создание списка. 2. печать списка на...

Запись элемента (в начало и в конец) и доступ к i-ому элементу двусвязного списка
Народ!Помогите написать прожку на С++ - двусвязный список из целочисленных элементов. Надо использовать структуру , содержащая указатель о...

Удалить все эл-ты двусвязного списка, находящиеся между его минимальным и максимальным эл-тами
Помогите, пожалуйста :cry: Требуется удалить все эл-ты двусвязного списка, находящиеся между его минимальным и максимальным эл-тами....

Даны числа D1 и D2 и указатель P0 на один из элементов непустого двусвязного списка. Добавить в начало списка новый
Даны числа D1 и D2 и указатель P0 на один из элементов непустого двусвязного списка. Добавить в начало списка новый элемент со значением D1...

Написать функции для включения, исключения и поиска элемента кругового списка с заголовком и без
Может быть кто-нибудь решал подобную задачу? Написать и протестировать функции для включения, исключения и поиска элемента кругового...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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