Форум программистов, компьютерный форум, киберфорум
Haskell
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
Модератор
Эксперт функциональных языков программирования
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,887

Структура данных для поиска

31.03.2016, 23:52. Показов 1188. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно:
1. добавлять элементы
2. определять, сколько элементов больше заданного числа (length $ filter (\x -> x > a))
Обе операции нужно делать за logn (ну, или быстрее)

Есть что-нибудь подходящее среди среди стандартных типов данных или нужно самому писать (сбалансированное дерево)?
1
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
31.03.2016, 23:52
Ответы с готовыми решениями:

Структура для поиска автора
Задача: дан список книг с авторами и годом издания найти книги с определенным названием и вывести их с авторами и годом издания на экран ...

Алгоритм и структура для поиска большого количества строк в другом массиве строк
Здравствуйте! Я решаю следующую задачу: Есть файл со "строками" (средняя длина которых 40-50 символов) и таких строк порядка 100000....

Структура данных для кэша
Уже мозг себе сломал. Сначала хотел дерево, в котором наиболее используемые элементы сдвигаются в правую часть. Потом понял, что это...

3
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38200 / 21132 / 4310
Регистрация: 12.02.2012
Сообщений: 34,738
Записей в блоге: 14
01.04.2016, 06:58
Может быть, поможет это: http://hackage.haskell.org/package/hashtables
1
Антикодер
Эксперт функциональных языков программирования
1888 / 870 / 48
Регистрация: 15.09.2012
Сообщений: 3,088
01.04.2016, 11:49
Если интересуют деревья вроде красно-чёрного и АВЛ, то я залил исходники(не знаю где я их взял):
АВЛ Дерево
Красно-чёрное дерево
Естественно, в hoogle, hackage и stackage есть полноценные реализации.
Но можете посмотреть и мой репозиторий, я готов подправить исходники если нужно.
Можно совместно подумать над проблемой, тема актуальная.
3
Модератор
Эксперт функциональных языков программирования
3136 / 2283 / 469
Регистрация: 26.03.2015
Сообщений: 8,887
01.04.2016, 16:32  [ТС]
Catstail,
Позже посмотрю внимательней, но, судя по названию, это не подходит. Хэши позволяют доставать элементы по ключу, но мне это не нужно.

XRuZzz,
Проблема в том, что "обычное" дерево умеет искать конкретное значение. Можно ли его приспособить для получения ответа на вопрос: "сколько в дереве элементов больше вот этого?".
Проблема актуальная, но чисто академическая (цель - обучение).
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.04.2016, 16:32
Помогаю со студенческими работами здесь

Структура данных для программы
Приветствую всех. Не могу вот в программе выбрать структуру данных. Подскажите пожалуйста. Структура должны быть примерно такой: id_p...

Структура базы данных для ИМ
Привет всем. Хотел бы попросить совета и направить на путь истинный. Как правильно организовать поиск по сайту по цвету одежды, размеру,...

Структура данных для хранения графов
Подскажите, пожалуйста, какую структуру данных лучше всего использовать для хранения графов, пример на картинке (ищу решения просто для...

Динамическая структура для хранения типизированных данных
Дано: ini-файл со следующей структурой раздел 1 список таблиц таблица 1 ... таблица j таблица 1 ...

Структура данных для ОЦК и ГЦК решеток
Доброго времени суток! Вопрос носит скорее теоретический характер. Изначально передо мной ставилась задача промоделировать процесс...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru