|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
||||||||||||||||
Словарь частоупотребимых слов25.02.2013, 21:23. Показов 2637. Ответов 17
Метки нет (Все метки)
Здравствуйте. Столкнулся со следующим задачей. На входе задается список слов, для которых указана частота из появления в словаре. Также на входе задается несколько слов или часть слов (возможно просто один символ). Необходимо вывести из введенного ранее словаря в порядке убывания по частоте слова которые содержать введенные значения.
Например. На входе задается словарь.
Я думаю решать следующим образом. Хранить данные в двумерном массиве, распологая их в порядке убывания частоты упоминания. А затем поиск значений осуществлять по всему массиву сверху на совпадения, если совпадение найдено, тогда они будут находится в порядке убывания. Но есть один момент. Если частота упоминаний совпадает, тогда вывод необходимо осуществлять в алфавитном порядке. Возможно кто поскажет правильный ли вариант решения я выбрал, а также сортировку лучше производить в процессе считывания, или после окончания считывания всех введенных слов?
0
|
||||||||||||||||
| 25.02.2013, 21:23 | |
|
Ответы с готовыми решениями:
17
Нужна программа для словаря, как быть? Полнотекстовый поиск в словаре Словарь данных для программы |
| 25.02.2013, 22:07 | |
|
Может лучше сформулировать так: человек набирает какой-то текст, а ему выпадает напр popup menu в котором список всех слов из словаря начинающихся с введенной части.
Если так то все очень банально: сортируете словарь (одномерный массив).по алфавиту, при вводе ищете минимальное совпадающее. Потом идете вправо по словарю пока совпадения не кончились. В результате известен диапазон подходящих индексов, напр [10-15]. Делаете временный массив индексов и сортируете его по частоте, вот и все
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 25.02.2013, 23:05 [ТС] | |
|
Массив по алфавиту я отсортирую, а как мне их потом связать с их частотой? Этот момент я не совсем понял.
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 25.02.2013, 23:36 [ТС] | |
|
Лучше наверное использовать списки?
0
|
|
|
1360 / 988 / 119
Регистрация: 30.07.2010
Сообщений: 5,297
|
|
| 25.02.2013, 23:48 | |
|
prizrak39, сортируете просто массив структур, а потом проходите за линию за запрос. Вообще, можно тут бор припилить, но это слишком сложно, мне кажется, для ваших потребностей.
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 25.02.2013, 23:52 [ТС] | |
|
Из всего я понял что лучше всего отсортировать массив по алфавиту и в нем уже осуществлять поиск. Интересно а возможно сортировать массив по мере чтения значений?
0
|
|
|
1360 / 988 / 119
Регистрация: 30.07.2010
Сообщений: 5,297
|
|
| 25.02.2013, 23:57 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 26.02.2013, 00:03 [ТС] | |
|
Если сортировать в порядке возрастания, то не совсем понятно как внутри одинакового количества упоминаний выводить значения по алфавиту.
0
|
|
| 26.02.2013, 00:18 | ||||||
|
Примерно так (сортировка по двум ключам):
0
|
||||||
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 26.02.2013, 00:21 [ТС] | |
|
Сначала сортируем по частоте, а потом внутри каждых одинаковых значений по алфавиту. Я правильно понял?
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 26.02.2013, 00:26 [ТС] | |
|
Большое спасибо постараюсь реализовать.
0
|
|
| 26.02.2013, 11:31 | ||||||||
. Отсортировав по первому ключу = частота Вы не сможете найти нужные слова
0
|
||||||||
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 26.02.2013, 11:40 [ТС] | |
|
Тогда получается необходимо пробежать по всему введенному массиву и найти совпадения и записать их в отдельный массив. Далее отсортировать этот массив по частоте. Правильно?
0
|
|
|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
|
| 26.02.2013, 18:42 [ТС] | |
|
А не подскажите какой лучше тип данных использовать? Например в C#. List я думаю не подходит, ArrayList возможно, тогда необходимо будет в нем хранить структуру?
0
|
|
| 26.02.2013, 19:21 | ||
|
Делать надо именно так, как сказано в #10. Если вам непонятно, что такое multikey sort, посмотрите в литературе.
0
|
||
| 26.02.2013, 19:21 | |
|
Помогаю со студенческими работами здесь
18
"Быстрый" словарь (с уникальными элементами) (код: желательно C++) Методы разреженного кодирования (sparse coding) с обучением словаря (dictionary learning) Создание программы для составления словарей. Что нужно знать? Особый итератор словаря. Итератор возвращающий нужные комбинации Autocomplete по словарю с учетом частоты появления слова Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|