Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2006.09.17;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.041 c
6-1145525827
Dadd
2006-04-20 13:37
2006.09.17
Как Убрать alert() из JavaScript в TwebBrowser и фреймах ?


15-1156859319
Chort
2006-08-29 17:48
2006.09.17
MathCad против Delphi


15-1156766876
TUser
2006-08-28 16:07
2006.09.17
Мул vs Осел


1-1154447915
Alex35
2006-08-01 19:58
2006.09.17
Подскажите реализацию алгоритма шифрования


2-1157007639
Neket
2006-08-31 11:00
2006.09.17
Database





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский