Форум программистов, компьютерный форум CyberForum.ru

Функция удаления чётных элементов двусвязного списка - C++

Восстановить пароль Регистрация
 
kondusov
2 / 2 / 0
Регистрация: 01.06.2013
Сообщений: 152
09.10.2013, 22:48     Функция удаления чётных элементов двусвязного списка #1
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
bool delete_even(circle_list *&list)
{circle_list *curr=list, *first=list; *temp=NULL;
 
if (Empty_list(list)) return false;
while (curr!=first){
if (list-<data%2==0)
{curr->prev->next=curr->next;
curr->next->prev=curr->prev;
temp=curr->next;
delete(curr);
curr=temp;}
else curr=curr->next;}
return 1;
}
не компилировал, но посмотрите, всё ли на месте?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.10.2013, 22:48     Функция удаления чётных элементов двусвязного списка
Посмотрите здесь:

Функция удаления из списка C++
C++ функция удаления и добавления элементов. что не так с програмой?
C++ Написать функцию удаления четных элементов двусвязного списка
Добавление и удаление элементов из двусвязного списка C++
Функция удаления элементов (список, стек) C++
C++ Функция, удаляющая элемент из двусвязного списка
Логическая функция, которая помогает определить количество чётных элементов в массиве C++
C++ Функция удаления всех четных элементов AVL-дерева

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
VEINHORN
542 / 91 / 22
Регистрация: 16.12.2011
Сообщений: 317
09.10.2013, 23:07     Функция удаления чётных элементов двусвязного списка #2
kondusov, вроде все на месте.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
09.10.2013, 23:36     Функция удаления чётных элементов двусвязного списка #3
Не знаю, как у вас организован список и куда указвают prev первого элемента списка и next последнего, но если на NULL, то такие элементы нужно обрабатывать особо.

Добавлено через 5 минут
И это как понять?
Цитата Сообщение от kondusov Посмотреть сообщение
list-<data%2==0
Добавлено через 5 минут
Цитата Сообщение от kondusov Посмотреть сообщение
circle_list *curr=list, *first=list;
Здесь присваиваете curr и first одно и тоже значение (curr == first). Потом идёт цикл с условием:
C++
1
while (curr != first)
Захода в цикл не будет.
Yandex
Объявления
09.10.2013, 23:36     Функция удаления чётных элементов двусвязного списка
Ответ Создать тему
Опции темы

Текущее время: 12:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru