Показать полную графическую версию : heap @ c++ stl
Что такое heap в C++ STL и как его можно эффективно использовать?
Когда он лучше, чем max_element() или sort()?
hasherfrog
14-03-2005, 13:07
>> Что такое heap в C++ STL
Шаблон такой, емнип.
>> как его можно эффективно использовать?
? %)
Если любите с шаблонами работать, почему бы его и не использовать (хоть эффективно, хоть неэффективно)?
hasherfrog
14-03-2005, 13:08
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/vclang98/HTML/sample_heap_(STL_Sample).asp
я имею ввиду make_heap, sort_heap. Их примеры я видел, но так и не понял, почему сортировка или поиск максимального элемента хуже.
По поводу эффективного использования, например: для быстрой вставки/удаления в середине контейнера эффективней использовать список, чем вектор. В этом смысле.
хоть эффективно, хоть неэффективно
Даже обидно становится. Я стараюсь при прочих равных условиях повышать эффективность
hasherfrog
14-03-2005, 18:30
pva
>> Я стараюсь при прочих равных условиях повышать эффективность
Дык это, хорошо. Считайте, что у меня такой неуклюжий юмор.
>> но так и не понял, почему сортировка или поиск максимального элемента хуже.
Почему хуже? Кто сказал, что хуже? Чем хуже? Вы же не объясняете... Остаётся догадываться... Любит человек шаблоны - пишет всё через heap. Ему говорят - так не эффективно, хочешь, пойдём с секундомером замеряем скорость работы- через heap и через qsort. А он говорит - зато у меня текст проги короче. И что? Кто прав?
1. Текст проги получается длиннее (если речь о сортировке или макс.элементе)
// heap
vector<int> v(10);
// fill ...
make_heap(v.begin(), v.end());
sort_heap(v.begin(), v.end())
// sort
vector<int> v(10);
// fill ...
sort(v.begin(), v.end());
2. В хелпе написано количество операций в среднем необходимых для выполнения действия (3*n для make_heap, n*log(n)/log(2) для sort_heap, n*log(n)/log(2) для sort). Если делать heap, а потом его сортировать, то количество операций немного превосходит sort. Если делать heap и искать максимальный элемент, то количество операций превосходит max_element втрое.
3. Не думаю, что коммитет по стандартизации C++ "просто так" включил heap в библиотеку. Может он что-то делает очень быстро, но я не знаю что..., а значит не знаю, зачем он нужен.
Нашёл описание на руском языке в ссылках на документацию. Это нужно для имитации priority queue на векторе. Понятно, что сортировка на heap хуже, чем специализированный алгоритм. Поэтому в примерах только pop_back демонстрируется.
hasherfrog
06-04-2005, 19:49
pva
Можно ссылку глянуть? А то я тут как раз написал очередь с приоритетами... А скорость у меня не просто критична, а апупеть как критична (нужно отрабатывать кучу udp-пакетов).
http://anatolix.naumen.ru/Books/cplusplus
Там много прикольных статей; советую:
Exceptional C++, More Exceptional C++ (Решение сложных задач на C++)
hasherfrog
12-04-2005, 15:58
Спасибо.
© OSzone.net 2001-2012
vBulletin v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.
Available in ZeroNet 1osznRoVratMCN3bFoFpR2pSV5c9z6sTC