|
0 / 0 / 0
Регистрация: 10.12.2012
Сообщений: 34
|
||||||||||||||||
Словарь частоупотребимых слов25.02.2013, 21:23. Показов 2628. Ответов 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 по словарю с учетом частоты появления слова Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|