Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Двусвязные списки

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование
Предыдущая тема :: Следующая тема  
Автор Сообщение
Pashany



Зарегистрирован: 06.07.2005
Сообщения: 3

СообщениеДобавлено: Пн Окт 10 2005 13:10    Заголовок сообщения: Двусвязные списки Ответить с цитатой

Нужно написать програмку каторая создает двусвязный список из
чисел и удалить из него отрицательные числа на С++(v3.1).
Несколько дней изучаю литературу но так и не понял как с этими списками работать.
Кто может подскажите как задать первый элемент, произвести вставку
в конец и после заданного эдемента, удалить элемент.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
sniper::p



Зарегистрирован: 04.10.2005
Сообщения: 237
Откуда: rus/73

СообщениеДобавлено: Пн Окт 10 2005 21:09    Заголовок сообщения: Ответить с цитатой

Вообще двусвязный список - это структура из одинаковых элементов, каждый из которых содержит как минимум 2 поля (чаще 3): указатель на следующий элемент и на предыдущий. Также имеется указатель на "голову" списка - первый элемент. Если список пуст - то этот указатель - NULL (т.е. нулевой). Может также иметься указатель на последний элемент списка - хвост.
pHead-->|data,pNext,pPrev|--><--|data,pNext,pPrev|-->NULL
Примерно так можно изобразить его графически. Ну а сам код, для того чтоб с ним работать - это заезжанная тема из книги. Берешь, например, Кернигана и читаешь.
Но могу показать пример объявления такой структуры.
Код:
struct Item{ // для простоты оформлено как стуктура
  int data;         // данные
  Item *pNext;  // указатель на такой же элемент в списке (след.)
  Item*pPrev    // указатель на предыдущий
}

// Объявляешь указатель на голову
Item *pHead;

// Теперь для примера покажу одну из функций по работе с ним
void Create()
{
  pHead = NULL;  // инициализация. Прежде, чем с ним работать, нужно ОБЯЗАТЕЛЬНО ИНИЦИАЛИЗИРОВАТЬ ЕГО НУЛЕМ
}

// Например, вставка в начало...
int FputFrontDEQl(int PutEl)
{
  // сохраняем старый указатель на голову
  SDEQList *pOldHead = pHead;
  // выделяем память по формату
  SDEQList *pnewEl = (SDEQList *) malloc(sizeof(SDEQList));
  // указатель на новую голову - указатель на только что созданный элемент
  pHead = pnewEl;
  pHead->pPrev=NULL;
  // указатель на новый следущий элемент - указатель на старую голову
  pHead->pNext=pOldHead;
  // а теперь устанавливаем новые связи между элементами
  // если список не был пуст - то устанавливаем ссылку на предыдущий
  if (pOldHead) pOldHead->pPrev=pHead;
  // кладешь, собственно данные в только что выделенную память
  pHeadL->data=PutEl;
};
Но!!! Это, вообще-то, далеко не все. Все-таки надо почитать... Там лучше рассказано. И еще одно: чтоб лучше понять, как все это устроено - на каждой строчке рисуешь картинку, что куда у тебя пошло (в смысле указателей). И, кстати, с помощью класса было бы это все сделать удобней
_________________
Нет предела совершенствованию
Вернуться к началу
Посмотреть профиль Отправить личное сообщение Отправить e-mail
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Программирование Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...