progs.biz  
Начало>C/C++>Основы C++>Урок 37
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
Обзор книг
Обзор программ

Бьерн Страуструп. Язык программирования С++. Специальное издание
Бьерн Страуструп. Язык программирования С++. Специальное издание
Заказать на Озоне



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

C/C++
Урок 37. Сортируем элементы списка

Продолжим работу с нашим списком, начатую на 28-м уроке

Для сортировки элементов списка мы воспользуемся методом пузырьков. Алгоритм его приблизительно такой - просматриваем элементы нашего списка соседними парами от начала до конца. Т. е. сначала смотрим пару нулевого и первого элементов, потом первого и второго и т. п. В каждой паре при необходимости меняем элементы - если они стоят не в том порядке. Так доходим до конца списка. Если мы поменяли хотя бы одну пару, то повторяем все с начала - т. е. начинаем смотреть пары от начала и до конца. И так будем делать до тех пор, пока при очередном проходе мы ничего не поменяем - тогда список и окажеться отсортированным.

Приступаем к коду.

В класс CList добавим объявление метода Sort:

class CList
{
public:
    ...
    // Сортировка.
    void Sort();
    ...

Добавим, естественно, и реализацию для этого метода:

void CList::Sort()
{
    bool b; // Меняли ли соседние элементы списка?
    do
    {
        b  = false; // пока ничего не меняли.
        // Смотрим элементы до предпоследнего.
        for (int i = 0; i<GetCount()-1; i++)
        {
            if (GetAt(i)->a > GetAt(i+1)->a)
            {
                Change(GetAt(i));
                b = true;
            }
        }
        
    }while (b);
}

С этим методом все.

Рассылки нашего сайта на 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 Игорь Алексеев