|
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
|
|||||||||||
Переставить буквы строки так, чтобы получился палиндром07.08.2017, 22:03. Показов 8115. Ответов 36
Метки нет (Все метки)
Здравствуйте, уважаемые пользователи прекрасного форума! Столкнулся с небольшой проблемой оптимизации при сдаче несложной задачи (все 0,1 секунды не хватает
((). Прошу всех, кто знает ответ, помочь в улучшении представленного ниже кода.Условие: На вход программы подаются заглавные латинские буквы, ввод этих символов заканчивается точкой. Напишите эффективную по времени работы и по используемой памяти программу, которая будет определять, можно ли переставить эти буквы так, чтобы получился палиндром (палиндром читается одинаково слева направо и справа налево). Программа должна вывести ответ «YES» или «NO», а в случае ответа «YES» – еще и сам полученный палиндром (первый в алфавитном порядке). Входные данные: На вход программы подаются заглавные латинские буквы, ввод этих символов заканчивается точкой. Выходные данные: Программа должна вывести ответ «YES» или «NO», а в случае ответа «YES» – еще и сам полученный палиндром (первый в алфавитном порядке). Примеры: Входные данные: GAANN. Выходные данные: YES ANGNA Мое решение:
Добавлено через 4 минуты Может передавать строку по ссылке? Но где именно внести изменения? Кто-нибудь знает? Добавлено через 5 минут Может просто переделать функцию из IsPal() с использованием указателей? Ума не приложу как это сделать ![]() Добавлено через 8 минут Пробовал менять функцию проверки строки на палиндромность. В нескольких тестах всего 0,007 секунды не хватает теперь Какой последний штрих можно применить к коду?
Может использовать другой цикл? Ума не приложу какой из них работает быстрее.
0
|
|||||||||||
| 07.08.2017, 22:03 | |
|
Ответы с готовыми решениями:
36
Из данной строки удалите наименьшее количество символов, так, чтобы получился палиндром Требуется изменить порядок букв так, чтобы получился палиндром Заданы две строки. Можно ли переставить буквы в одном из слов так, чтобы слова стали одинаковыми? |
| 08.08.2017, 16:15 | ||
|
ЗЫ и конечно эрейзить ничего не надо - вообще работать не со строками а с массивами чаров. Добавлено через 11 минут UPD а в середину засовывать и все переписывать тоже не надо. Можно сформировать 2 строки результата - прямую и обратную часть, и выводить подряд - прямую, среднюю букву (если он есть) - обратную прямо в принте, не гоняя символы по памяти.
0
|
||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 08.08.2017, 16:15 | |
|
_Ivana, а если кусать не по паре, а сразу находить количество одинаковых букв, а уж потом проверять найденное количество на четность. Так на мой взгляд будет легче.
0
|
|
| 08.08.2017, 16:21 | ||
|
мановар, если не стоит задача
![]() Добавлено через 2 минуты Но можете и через мап, перебирая ключи в порядке возрастания и смотря на накопленное количество - будет тот же алгоритм, но на серьезных структурах данных, больше по размеру кода и выполняться медленнее
0
|
||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
||
| 08.08.2017, 16:28 | ||
|
0
|
||
| 08.08.2017, 16:32 | |
|
мановар, возможно я не глубоко понял ваше предложение, но в моем варианте есть только сортировка и один пробег по массиву со складыванием букв в пару заранее подготовленных мешков. Быстро, дешево, надежно и практично
Но разумеется, даже такая простая задача может быть решена многими способами.
0
|
|
|
Модератор
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,980
|
|||||||
| 08.08.2017, 16:39 | |||||||
![]()
0
|
|||||||
| 08.08.2017, 16:46 | ||
Такие олимпиадные задачи принято делать не по уму - нарезать сразу глобальный массивы результатов и писать все туда
1
|
||
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 08.08.2017, 16:51 | |
|
_Ivana, да те же яйца только в профиль. Допустим получили после сортировки
[AAAABBCCCCCDDDDDD] топаем вперед по нашему массиву : A - 4 шт. четн., делим на 2, по 2 шт. в наши мешки (или в один, а потом реверсом), с B - то же самое, C - 5 шт. нечет, запоминаем, устанавливаем флаг и т.д. Это для того что бы избежать [CC] в мешки, [CC] в мешки, [CD] - не в мешки, надо возвращаться и колупаться по новой. Короче облегчить немного труд.
0
|
|
|
Модератор
12843 / 7592 / 1766
Регистрация: 25.07.2009
Сообщений: 13,980
|
|
| 08.08.2017, 16:57 | |
|
Не по теме: Ну да, спортсмен из меня тот ещё... мановар, так это их все пересчитывать прийдётся, по сути та же фигня, что с мапой или массивом счётчиков, только плюс к тому - отсортировали зачем-то. Тут же вся прелесть в том, что просто по две штуки берём, если одинаковые - рассовываем по краям, если нет - первую пихаем в середину, устанавливаем флаг и начиная со второй снова берём по две штуки...
1
|
|
| 08.08.2017, 17:02 | |
|
Ну вот, приятно, что кто-то оценил прелесть подобных оптимизаций на спичках и ловлей блох
Асимптотика то все равно О(n*log(n)) в любом случае - хоть с мапами, хоть по массиву несколько раз бегай...
0
|
|
| 08.08.2017, 17:23 | |
|
Я свою оценку взял из необходимости сортировки в моем варианте и поиска по ключам в мапе в других. Если без мапы искать по массиву, предполагая конечность алфавита, тогда О(n*m), где m-длина алфавита. Линии не вижу.
0
|
|
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 08.08.2017, 17:34 | |
|
Понял что не догонял. При
[AAAABBCCCCCDDDDDD] должны получить в [AABCCDDDCDDDCCBAA] , а не [AABDDDCCCCCDDDBAA] как думал.
0
|
|
|
1719 / 568 / 187
Регистрация: 12.03.2016
Сообщений: 2,169
|
|
| 08.08.2017, 17:43 | |
|
_Ivana, за бурным обсуждением данная деталь и выскользнула из головы, бывает.
0
|
|
| 08.08.2017, 17:43 | |
|
Помогаю со студенческими работами здесь
37
Переставить буквы в строке так, чтобы первой буквой была гласная Определить, можно ли переставить буквы так, чтобы получился палиндром
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы
Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
|
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция
Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
|
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
|
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
|
|
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
|
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика
Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
|
Модель здравосохранения 17. Планы на выгорание
anaschu 23.05.2026
Вот конкретная схема реализации:
В классе Работник добавить:
накопленнаяУсталость — растёт каждый час работы, снижается в перерывы и болезни
коэффициентПрезентеизма — снижает продуктивность. . .
|
Изменение цветов в палитре gif файла aka фавикона
russiannick 23.05.2026
Изменение цветов в палитре gif файла, юзаемого как фавиконка в составе html-файла, помещенная в base64, средствами нативного Java Script, навеянное сном в майский день.
Для работы необходим браузер,. . .
|