С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
ГузелькаС
5 / 5 / 0
Регистрация: 04.12.2011
Сообщений: 178
#1

Удаление всех элементов из динамической очереди - C++

30.11.2013, 19:36. Просмотров 523. Ответов 5
Метки нет (Все метки)

Покажите пожалуйста пример удаления.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.11.2013, 19:36
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Удаление всех элементов из динамической очереди (C++):

Удаление и добавление элементов динамической структуры данных - C++
Структура "Абитуриент": - фамилия, имя, отчество; - год рождения; - оценки вступительных экзаменов (3); - средний балл аттестата. ...

Удаление положительных элементов очереди - C++
Нужно написать программу для удаления положительных элементов очереди :) ВВод очереди осуществляется так: void vvod_ochered(int mas,int...

Как происходит удаление элементов из очереди? - C++
Объясните пожалуйста как происходит удаление элементов из очереди!! Допустим есть статическая очередь из 10 элементов. Как их удалить? как...

Создание очереди и удаление элемента очереди по усмотрению пользователя - C++
Вот код он создает очередь и должен удалить элемент очереди по усмотрению пользователя проблема заключается в том что при попытки удалить...

Создание очереди чисел (умножение элементов, добавление и удаление, проверка значений) - C++
Здравствуйте уважаемые форумчане... Тут такое дело, я пишу контрольную и задание меня смущает, так что прошу помощи! Пожалуйста, если можно...

Поиск максимального и минимального элемента в очереди, удаление элементов между максимальным и минимальным - C++
Задача следующая: написать функцию, которая ищет максимальный и минимальный элементы в очереди и удаляет элементы, находящиеся между ними....

5
Oberyn Martell
5 / 5 / 0
Регистрация: 15.05.2013
Сообщений: 36
30.11.2013, 19:46 #2
Просто поочередно удалить каждый элемент:
C++
1
2
3
4
5
6
7
8
void deleteAll(node* n){
        node* t;
        while (n) {
                t = n->next;
                delete n;
                n = t;
        }
}
1
ГузелькаС
5 / 5 / 0
Регистрация: 04.12.2011
Сообщений: 178
30.11.2013, 19:59  [ТС] #3
n -ссылка на первый элемент очереди?
0
Oberyn Martell
5 / 5 / 0
Регистрация: 15.05.2013
Сообщений: 36
30.11.2013, 20:00 #4
Цитата Сообщение от ГузелькаС Посмотреть сообщение
n -ссылка на первый элемент очереди?
все верно
1
ГузелькаС
5 / 5 / 0
Регистрация: 04.12.2011
Сообщений: 178
30.11.2013, 20:19  [ТС] #5
А вы можете проверить несколько моих функций, связанных с динамической очередью? Я не уверена, правильно ли я их реализовала. Но программа работает. Все ли элементы очереди удаляются, при удалении элемента массива, который содержит ссылку на первый элемент очереди.


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
void deleteAll(Manager* n){
        Manager* t;
        while (n) {
                t = n->next;
                delete n;
                n = t;
        }
}
//удалить  отдел
bool DelDepartment(int index)//index- это индекс отдела в магазине (массив)
{ //перед тем как удалить отдел необходимо удалить всех менеджеров из этого отдела
    Manager *tmp;
    tmp=shops[index].department.pFirst;
    deleteAll(tmp);
    
    cout<<"\n";
    for (int i=index; i<countDepartment-1;i++)
    {
        shops[i]=shops[i+1];
        
    }
    countDepartment--;
    return true;
 
}
 
 
bool AddDepartment(string  newName)
{//нужно проверить есть ли место в  списке
    if (countDepartment<MaxCountDepartments)
    {
        shops[countDepartment].nameDepartment=newName;
//тут ничего больше не надо добавить?
        countDepartment++;
        return true;
    }
    return false;
}
0
Oberyn Martell
5 / 5 / 0
Регистрация: 15.05.2013
Сообщений: 36
01.12.2013, 08:28 #6
C++
1
2
3
4
5
6
7
8
9
10
11
bool AddDepartment(string  newName)
{//нужно проверить есть ли место в  списке
    if (countDepartment<MaxCountDepartments)
    {
        shops[countDepartment].nameDepartment=newName;
//тут ничего больше не надо добавить?
        countDepartment++;
        return true;
    }
    return false;
}
Тут нужно создать новый узел очереди, занулить его и вставить на нужное место в массиве.
0
01.12.2013, 08:28
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.12.2013, 08:28
Привет! Вот еще темы с ответами:

Очистка динамической памяти очереди - C++
Доброго времени суток! Я вот думаю-думаю, но докумекать не могу. Я пишу очередь (основываюсь на логику и принцип очереди) так вот,...

Удаление всех элементов вектора - C++
Как удалить все элементы вектора. Например Создаём пустой вектор vector&lt;int&gt;numb; заполняем его пятью элементами ...

Разработать программу формирования очереди, содержащей целые числа, и упорядочивания по возрастанию элементов в этой очереди. - C++
Доброе всем время суток! Помогите пожалуйста! Разработать программу формирования очереди, содержащей целые числа, и упорядочивания по...

Удаление всех элементов после запятой - C++
Написать программу, которая бы удаляла все элементы после запятой! Я вот написал программу, но меня смущает мигания курсора! Он должен...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.