Форум программистов, компьютерный форум, киберфорум
Visual C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 10.11.2010
Сообщений: 41

Удаление элементов из дека

10.12.2010, 15:27. Показов 1727. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите плиз. Пишу шаблон дека. Что-то с удалением, совсем никак не выходит. Я так понял в деке надо удалять либо сверху, либо снизу.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.12.2010, 15:27
Ответы с готовыми решениями:

Считывание элементов дека с файла и запись дека в файл
Доброго времени суток. Я написал код программы про дек с ограниченным входом слева (то есть с него можно удалять элементы как с начала,...

Удаление последнего элемента Дека
Все работает, кроме удаления последнего элемента. Подскажите пожалуйста, что не так? #include <cstdlib> #include <iostream>...

Используя модуль для реализации дека целых чисел, реализовать очередь на базе дека
Уважаемые программисты!Очень нужна Ваша помощь: (помогите решить, разобраться или хотябы просто объяснить алгоритм, с чего начинать, как...

6
 Аватар для Manjak
270 / 176 / 46
Регистрация: 12.03.2010
Сообщений: 494
10.12.2010, 15:56
Начнем с модели управления памятью. Как у тебя память распределяется?
0
0 / 0 / 0
Регистрация: 10.11.2010
Сообщений: 41
10.12.2010, 16:03  [ТС]
Как обычный примитив дека.

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
template <typename TYPE>
struct deque
{
        TYPE val;
        deque *prev,*next;
};
 
template <typename TYPE>
class Deque
{
    deque<TYPE> *head,*tail;
public:
    Deque(void) 
        { head=tail=NULL; }
        ~Degue(void)
        {
           // ХЗ
        } 
        void PushFront(const TYPE & x) //ввод эл-та в начало
        {
          deque<TYPE> *tmp1=new deque<TYPE>;
          tmp1->val=x;
          if (head==0)
           {
            head=tmp1;//единственный элемент пока и начало
            tail=tmp1;//и хвост
           }
          else
           {
            head->prev=tmp1;
            tmp1->next=head;
            head=tmp1;
            head->prev=0;
           }
        }
 
        void PushBack(const TYPE & x)
        {
        deque<TYPE> *tmp=new deque<TYPE>;//создаем элемент
        tmp->val=x;
        if (tail==0)//если пустой дек
           {
                head=tmp;
                tail=tmp;                
           }
        else
           {
                tail->next=tmp;//следующий элемент за  хвостом новый
                tmp->prev=tail;//для нового элемента предыдущий - хвост
                tail=tmp;//хвост новый элемент
                tail->next=0;
            }
       
 
        }
0
 Аватар для Manjak
270 / 176 / 46
Регистрация: 12.03.2010
Сообщений: 494
10.12.2010, 16:09
обычный двусвязный список, у тебя память никак вообще не организовывается.

Удалить элемент в начале: следующему элементу установить указатель prev в нуль, удалить элемент, изменить указатель head

Удалить элемент в конце : предыдущему элементу установить указатель next в нуль, удалить элемент, изменить указатель tail

Удалиль элемент в средине: следующему элементу установить указатель prev = this->prev,
предыдущему элементу установить указатель next = this->next, удалить
элемент.
0
0 / 0 / 0
Регистрация: 10.11.2010
Сообщений: 41
10.12.2010, 16:18  [ТС]
эмммммм........

следующему элементу установить указатель prev в нуль, удалить элемент, изменить указатель head
я так понял, что то наподобие этого:
C++
1
2
3
4
5
        deque<TYPE> *S;
    S=head;
    S->next->prev=NULL;
    delete S;
    head=S;
если да, то ошибка работы с памятью.
0
 Аватар для Manjak
270 / 176 / 46
Регистрация: 12.03.2010
Сообщений: 494
10.12.2010, 16:24
Последняя строка - ахинея полная Ты уже удалил элемент, зачем в пустое место устанавливать указатель?

C++
1
2
3
4
5
deque<TYPE> *S;
        S=head;
        S->next->prev=NULL;
        head=S->next;
        delete S;
ПС. Это голый код и он не безопасный, нужно учитывать возможность пустого контейнера или удаление последнего элемента, но пока и так пойдет
0
0 / 0 / 0
Регистрация: 10.11.2010
Сообщений: 41
10.12.2010, 16:32  [ТС]
примногоблагодарен.

Добавлено через 2 минуты
в деструкторе тупо зациклить удаление пока (!head), видимо так?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.12.2010, 16:32
Помогаю со студенческими работами здесь

Как сделать процедуры вывода и удаления элементов из дека на основе кода?
Как вывести все элементы дека, введенные ранее? И как потом удалить их? Можете помочь с процедурами вывода и удаления элементов дека на...

Создание программы со своей библиотекой ( удаление элементов с N по M в строке и удаление лишних пробелов(если 2 и более оставить один))
добрый день. помогите, пожалуйста понять мои ошибки в работе. Мне нужно написать программу со своей библиотекой, которая включает в себя...

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

Создание дека
Здравствуйте. Изучаю STL и считаю, что в изучении программирования нет ничего лучше, чем создание велосипедов. От чего вы**ал свой...

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


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru