progs.biz  
Начало>C/C++>Основы C++>Урок 32
C#
VB.NET
Visual C++.NET
ASP.NET
Visual C++ 6
WinAPI
C/C++
Delphi
C++ Builder
Java
SQL
PHP
DirectX
Visual Basic 6.0
Ассемблер
Интернет
Сист. прогр-ние
Pocket PC
Обзор книг
Обзор программ

И. Портянкин. Swing. Эффектные пользовательские интерфейсы
И. Портянкин. Swing. Эффектные пользовательские интерфейсы
Заказать на Озоне



Яндекс-цитирования

C/C++
Урок 32. Удаление элемента из списка

Рассмотрим стандартную задачу - удаление элемента из списка.

Алгоритмически мы должны рассмотреть два случая - когда удаляем самы первый элемент из списка и когда удаляем элемент из середины или конца списка.

Вот код для нашего метода (не забудьте внести объявление этого метода в сам класс):

bool CList::RemoveData(int a, int b)
{
    // Если список пуст
    if(IsEmpty())
        // то выходим.
        return false;
    // Получаем элемент для удаления.
    CData * pData = FindData(a, b);
    // Если такого элемента в списке нет
    if(pData == NULL)
        // то выходим.
        return false;
    // Если удаляемый элемент - первый в списке.
    if(pData == m_pFirst){
        // Делаем первым следующий за ним элемент списка.
        m_pFirst = pData->m_pNext;
        // Освобождаем память, которую занимал удаляемый элемент.
        delete pData;
        // И выходим.
        return true;
    }
    // Если удаляемый элемент - не первый в списке.
    // То делаем так, чтобы элемент, находящийся в списке
    // перед удаляемым, показывал на следующий за удаляемым элемент.
    GetPrev(pData)->m_pNext = pData->m_pNext;
    // Освобождаем память, которую занимал удалаемый элемент.
    delete pData;
    // И выходим.
    return true;
}

Код должен быть ясен из комментария. Если удаление произошло, то возвращяем true, если нет, то false. В этом методе мы использовали другие методы (GetPrev, FindData), написанные на прошлых уроках.

Рассылки нашего сайта на Subscribe.Ru
Visual C++, MFC
C# и .NET
VB.NET
ASP.NET new!
Win API
C/C++
Delphi
Java
HTML, PHP, mySQL, WEB-дизайн
Flash MX
C++ Builder
Ассемблер
SQL Server
DirectX
Обзор книг
Обзор программ
Новости сайта progs.biz


 
 
Копирование любых материалов сайта без разрешения авторов и владельцев сайта запрещено.
© 2002-2008 сайт progs.biz
© 2002-2008 Игорь Алексеев