В словаре, который я использовал, содержится 230 ООО слов
В словаре, который я использовал, содержится 230 ООО слов, а даже простейшее сравнение анаграмм требует не меньше 1 мкс, поэтому полное время работы составит приблизительно:
230 ООО слов * 230 ООО сравнений/слово * 1 мкс/сравнение = 52 900*106
микросекунд = 52 900 секунд = 14.7 часа
Можно ли найти способ обойти эти вычислительные ловушки?
Озарение «ага!»: придумать способ вычисления сигнатуры слова таким образом, чтобы все слова, принадлежащие к одному классу анаграмм, имели одинаковую сигнатуру, затем собрать эти слова вместе. При этом исходная задача разделяется па две подзадачи: выбор сигнатуры и объединение всех слов с одинаковой сигнатурой. Подумайте над этим самостоятельно, прежде чем читать дальше.
Для решения первой подзадачи воспользуемся сортировкой: упорядочим буквы слова в алфавитном порядке . Сигнатурой слова deposit будет deiopst, причем это же сочетание букв является также сигнатурой слова dopiest и любого другого слова из этого класса анаграмм. Для решения второй подзадачи упорядочим слова так, чтобы их сигнатуры располагались в алфавитном (лексикографическом) порядке. Лучшая иллюстрация была предложена Томом Каргиллом (Tom Cargill): сортировать нужно сначала в этом порядке (взмах рукой слева направо), затем в этом (сверху вниз). В разделе 2.8 описана реализация этого алгоритма.
Опубликовал vovan666
April 16 2013 23:34:45 ·
0 Комментариев ·
4041 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.