|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
||||||
Оптимизация программы15.02.2020, 16:04. Показов 1059. Ответов 12
Метки нет (Все метки)
Добрый день, поставлена следующая задача:
Выписать все слова, которые являются анаграммами друг для друга, например «замок» и «мазок». Проверка слов должна быть регистронезависимой. Слова, для которых анаграммой является только оно само, выписывать не нужно, даже если это слово встречается в тексте в разном регистре. Формат ввода В первой строке идёт целое число n (1 ≤ n ≤ 100 000), количество исходных слов. Далее следует n слов, по одному слову в строке, слова могут идти в разном регистре! Формат вывода В одной строке должны идти слова, которые являются анаграммами друг для друга, в нижнем регистре, через пробел. Порядок слов — лексикографический (как в словаре). Порядок строк так же лексикографический. Пример Ввод 11 окорок петлей Плетей рококо теплей Тишь ТОМНО тонко тонок тоном шить Вывод окорок рококо петлей плетей теплей тишь шить томно тоном тонко тонок Имеется следующий полностью рабочий код:
Даю свой код, который тратит меньше всего времени из всех попыток(4025мс) Буду очень рад, если вы поможете оптимизировать код. Также знаю, что можно решить задачу через словари, но я не представляю, как это сделать
0
|
||||||
| 15.02.2020, 16:04 | |
|
Ответы с готовыми решениями:
12
Оптимизация программы
|
|
5234 / 3479 / 1175
Регистрация: 21.03.2016
Сообщений: 8,306
|
|
| 15.02.2020, 16:11 | |
|
0
|
|
|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
|
| 15.02.2020, 16:19 [ТС] | |
|
Semen-Semenich, спасибо, но мне нужно оптимизировать именно этот код, иначе от предпода прилетит за списывание
0
|
|
|
|
|||||||||||
| 15.02.2020, 16:42 | |||||||||||
|
А разве
0
|
|||||||||||
|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
|
| 15.02.2020, 16:44 [ТС] | |
|
Эквивалентно, но, к сожалению, не помогает
0
|
|
|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
|
| 15.02.2020, 16:50 [ТС] | |
|
Только что заметил, что часть кода не скопировалась: в начале должно быть также n = int (input())
0
|
|
|
|
||||||
| 15.02.2020, 16:54 | ||||||
|
Относительно словарей -- информация к размышлению. Код
True. Так что я бы пользовался словарями. Насчет времени -- не знаю, но алгоритм был бы правильным.
1
|
||||||
|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
|
| 15.02.2020, 16:59 [ТС] | |
|
Если не получится увеличить скорость того кода, то придется со словарями пытаться что-то делать. Взялся бы сразу, если бы умел с ними работать)
0
|
|
|
|
||
| 15.02.2020, 16:59 | ||
|
0
|
||
|
|
|
| 15.02.2020, 17:14 | |
|
bulk_bulk, Если вас не учили словарям и знать их вы не обязаны, то зачем же использовать словари. Я бы попробовал вычислять множества к каждому слову вне цикла, а потом заходить в цикл и сравнивать уже готовые множества. По-моему, работало бы быстрее. Хотя после моей предыдущей неудачной оптимизации я уже сомневаюсь.
0
|
|
|
3 / 3 / 0
Регистрация: 15.02.2020
Сообщений: 9
|
|
| 15.02.2020, 17:30 [ТС] | |
|
palva, не помогает в плане уменьшения времени
Создание дополнительного списка перед циклом с теми же элементами, но в виде множества, занимает слишком много памяти То есть, в цикле сравниваю элементы списка с множествами, а потом уже добавляю по индексу элемент из основного списка, чтобы порядок букв был верный Как сделать без дополнительного списка, понятия не имею
0
|
|
| 15.02.2020, 17:30 | |
|
Помогаю со студенческими работами здесь
13
Оптимизация программы
Оптимизация программы, имитирующей меню в ресторане Типы оптимизация: черная оптимизация, серая оптимизация и белая оптимизация Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|