Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.09.17;
Скачать: CL | DM;

Вниз

Структура данных, вроде АВЛ-дерева   Найти похожие ветки 

 
partizan   (2006-08-07 19:21) [0]

Есть набор елементов, а каждого елемента есть ранг (некоторое целое число).

Нужна такая структура, которая позволяла бы быстро вычислить порядковый номер определенного ел-та (у ел-та с наибольшим рангом порядковый номер - 1 ), другими словами количество елементов, у которых ранг больше заданного.

Новые елементы добавляются всегда с наибольшим рангом (на 1-е место).
Удаляться может любой елемент.
Так же любой елемент может "поднятся" на 1-е место

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

Но межет есть идеии, как это реализовать по-проще?


 
Мефисто   (2006-08-07 20:16) [1]

"Фундаментальные алгоритмы и структуры данных в Delphi" Джулиан Бакнелл (один из разработчиов в компании TurboPower).
Исходники к книге не прилагаются, только на сатах издательства. К примру тут:
http://materials.diasoft.kiev.ua/alg_delphi/alg_delphi.zip


 
partizan   (2006-08-07 20:49) [2]

Мне исходники не нужны, мне идея нужна.
Но всеравно спасибо, что хоть кто-то откликнулся


 
Мефисто   (2006-08-07 20:53) [3]

А я тебе на книгу намекнул ;)


 
Alex Konshin ©   (2006-08-08 10:23) [4]

Твоя задача решается с помощью моего юнита Arrays (смюна моем сайте из анкеты).
Достаточно будет просто завести какой-то из TSortedArray. Логический индекс элемента и будет твоим искомым числом.
Насколько это будет эффективно для твоего случая - не знаю, т.к. мало данных о твоей задаче. Работать должно быстро, но возможно, что для твоего конкретного случая можно придумать что-то и по-быстрее.



Страницы: 1 вся ветка

Текущий архив: 2006.09.17;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.056 c
15-1156709967
Petr V. Abramov
2006-08-28 00:19
2006.09.17
Еще раз про откаты


15-1156826293
Slay
2006-08-29 08:38
2006.09.17
date


1-1155106048
-=Germe$=-
2006-08-09 10:47
2006.09.17
Где ошибка? Подскажите....


6-1138091589
Makhanev
2006-01-24 11:33
2006.09.17
получение MAC адресов сетевых карт в offline


15-1156173016
SergP.
2006-08-21 19:10
2006.09.17
Кто знает как убрать банеры на сайте www.****.nm.ru ?