Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 06.05.2023
Сообщений: 1

Айбар и две строки

06.05.2023, 06:57. Показов 672. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Айбару подарили две строки a и b длины n, которая состоит из строчных латинских букв.

Айбар хочет сделать эти две строки одинаковыми. За один ход Айбар может выбрать любую длину l (1≤l≤n) и выполнить следующую операцию:

Он может выбрать одну подстроку строки a длины l и перевернуть ее;
Он в тот же момент должен выбирать подстроку строки b длины l и перевернуть ее.
То есть, за один ход Айбар может перевернуть одну подстроку из a и одну подстроку из b длины l.

Заметьте, что Айбар когда выбирает подстроку, их границы могут быть различны. Главное – Айбар должен выбирать подстроки одинаковых длин. Например, если l = 2 и n = 4, Айбар может перевернуть a[1…2] и b[2…3], a[3…4] и b[1…2], a[2…3] и b[2…3].

Скажите, может ли Айбар сделать строки a и b одинаковыми после какого то (либо 0) количества ходов.

Подстрока строки s — это последовательный отрезок букв из s. Например, defor – это подстрока codeforces, а fors — нет.

Входные данные
В первой строке входных данных дано одно целое число n (1≤n≤2⋅105) – длина строк.

Во второй строке входных данных дана строка a, состоящая из n строчных латинских букв.

В третьей строке входных данных дана строка b, состоящая из n строчных латинских букв.

Выходные данные
Выведите «YES» (без кавычек), если Айбар может сделать строки одинаковыми, или «NO» (без кавычек) иначе.

Недавно начал изучать python, как можно сделать такую программу?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.05.2023, 06:57
Ответы с готовыми решениями:

Начиная с первой строки сдвинуть все строки на две вниз, а последние две переместить на место первых двух
дан двумерный массив, начиная с первой строки сдвинуть все строки на две вниз, а последние две переместить на место первых двух, (напишите...

Начиная с первой строки сдвинуть все строки на две вниз, а последние две перенести на место первых двух строк
Используя Procedure Swap!

Удалить из файла две первые и две последние строки и добавить строки с экрана в начало и конец файла
Задание: Создать текстовый файл. Заполнить его произвольным числом строк. Удалить из файла две первые и две последние строки и...

2
44 / 31 / 13
Регистрация: 19.12.2022
Сообщений: 107
06.05.2023, 12:51
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
n = int(input())
a = input()
b = input()
 
if sorted(a) != sorted(b):
    print("NO")
else:
    l = 0
    r = n
    while l < r and a[l] == b[l]:
        l += 1
    while l < r and a[r-1] == b[r-1]:
        r -= 1
    a = a[:l] + a[l:r][::-1] + a[r:]
    b = b[:l] + b[l:r][::-1] + b[r:]
    print("YES")
В общих чертах вот так должно работать.
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
06.05.2023, 13:11
Цитата Сообщение от tvelony Посмотреть сообщение
Недавно начал изучать python, как можно сделать такую программу?
И зачем в олимпиады полезли?
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.05.2023, 13:11
Помогаю со студенческими работами здесь

Слить две строки, вставив символы одной строки между символами другой строки
Строка a из n символов лексикографически меньше строки b из n символов, если существует такой индекс j, что aj &lt; bj, а для всех i &lt; j...

Задача на строки. Даны две строки. Определить можно ли из символов первой строки получить вторую строку
Задача на строки. Даны две строки. Определить можно ли из символов первой строки получить вторую строку.( написать подпрограммой используя...

Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки
Сгенерировать две произвольные строки и определить, является ли какое-либо слово первой строки частью второй строки. 1. Я дуб дубом,даже...

На плоскости заданы две окружности. Требуется проверить, пересекаются они или нет. Входные данные: в файле две строки, в
ввод и вывод данных осуществлять через файлы На плоскости заданы две окружности. Требуется проверить, пересекаются они или нет. Входные...

Разработать две подпрограммы, одна из которых сравнивает две строки по лексикографическому порядку, а другая обменивает значения двух строк
Помогите пожалуйста! Разработать две подпрограммы, одна из которых сравнивает две строки по лексикографическому порядку, а другая...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru