Данный метод является модификацией метода . Исходная последовательность делится на групп по элементов в каждой2. Для каждой группы в памяти выделяются дополнительные поля, совокупность которых образует так называемую зону накопления. Элементы каждой группы просматриваются, и определяется наименьший элемент, который заносится в соответствующее поле зоны накопления. Затем просматриваются элементы в зоне накопления, и наименьший из них заносится в выходную последовательность. Для определения следующего элемента этой последовательности осуществляется просмотр в группе, элемент которой был записан в отсортированную последовательность, и наименьший из оставшихся заносится в соответствующее поле зоны накопления. Затем снова просматриваются элементы в зоне накопления и т. д. В результате последовательно формируется упорядоченная выходная последовательность. Метод характеризуется числом сравнений
и дополнительными затратами памяти для создания зоны накопления и выходной последовательности. Сноски:
2 Если n – не точный квадрат, то к последовательности можно добавить один дополнительный элемент с условно максимальным значением ∞, который после сортировки отбрасывается.
Опубликовал Kest
December 24 2009 19:55:09 ·
1 Комментариев ·
15440 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
.14Ц ПРОСТО February 10 2015 18:46:11
vector<int> TetragonSort(vector<int> arr)
{
int min=0, i, j, k;
vector<int> additList, resultList;
int nGroups = sqrt(arr.size());
if (nGroups*nGroups < arr.size( ))
nGroups++;
//заполнение первичными значениями дополнительнгго списсска
for (i = nGroups*min; i < arr.size( ); i += nGroups)
{
min = i; //индекс минимального
for (j = i + 1; j < i + nGroups && j < arr.size( ); j++)
{
if (arr[j] < arr[min])
min = j;
}
//добавление эл-а в доп. список и заполние эл-а в осн.
additList[i / nGroups] = arr[min];
arr[min] = INT_MAX;
}
//основной цикл
while (true)
{
//формирование результата------------
min = 0; //индекс минимального
for (k = 1; k < additList.size(); k++)
{
if (additList[k] < additList[min])
min = k;
}
resultList.push_back(additList[min]);
//------------------------------------
if (resultList.size() == arr.size()) //точка выхода
break;
//основная работа
i = nGroups*min; //начальная точка просмотра
min = i; //индекс минимального
for (j = i + 1; j < i + nGroups && j < arr.size(); j++)
{
if (arr[j] < arr[min])
min = j;
}
//добавление эл-а в доп. список и заполние эл-а в осн.
additList[i / nGroups] = arr[min];
arr[min] = INT_MAX;
}
return resultList;
}
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.