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

Задача по перестановкам

20.12.2020, 09:54. Показов 2258. Ответов 1

Студворк — интернет-сервис помощи студентам
Есть перестановка a длины n, причем n — четно.
Перестановка длины n — это последовательность, состоящая из n целых чисел, причем каждое из целых чисел от 1 до n встречается в этой последовательности ровно один раз.
Стоит задача построить перестановку b длины n по следующим правилам. Изначально, b — это пустая последовательность. Затем нужно производить следующие операции до тех пор, пока a не станет пустой (каждая операция состоит из трех этапов):
1. выбрать два соседних элемента в a, назовем их p и q;
2. удалить p и q из a (таким образом, длина a уменьшится на два);
3. добавить p и q в начало b, сохранив их относительный порядок.
Легко показать, что после того, как a станет пустой, последовательность b будет являться перестановкой длины n.
Определить лексикографически минимальную перестановку b, которую можно получить с помощью описанных операций.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.12.2020, 09:54
Ответы с готовыми решениями:

Нужна программа по перестановкам!
Нужна программа которая выведет все возможные перестановки 5 чисел(желательно результат сохранив в txt файл) Можно сразу скинуть exe файл)

Вычисление определителя как суммы по перестановкам
Как это можно сделать?

Какие основные методы перехода от перестановки из n-1 объектов к перестановкам из n объектов?
Какие есть основные методы перехода от перестановки из n-1 объектов к перестановкам из n объектов?

1
 Аватар для LegionK
393 / 263 / 193
Регистрация: 02.05.2017
Сообщений: 1,003
20.12.2020, 20:28
Заведите массив в котором будут храниться пары значений :

a[i],a[i+1]. Для всех i от 1 до n-1

(и a[i+1],a[i], если "относительный порядок" зависит от порядка выбора p и q, а не только от их позиций в a)

Отсортируйте его по возрастанию. После этого можно жадно выбирать ответ. Идем сначала массива. Если мы смотрим на элемент k массива, и ни его первое значение ни его второе значение мы раньше не брали, записываем в конец ответа эти значения, сначала первое, потом второе.

В конце выводим ответ. N log N сложность, если нормально написать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.12.2020, 20:28
Помогаю со студенческими работами здесь

Олимпиадная задача по программированию. PascalABC.NET. Задача L. Переключение между окнами
Когда пользователь работает в операционной системе Winux, у него часто запущено несколько приложений. Каждое из приложений работает в...

Васильев C# Глава 8 задача 2 (Просьба объяснить формулировку(задача внутри)
Текст задачи Написать программу , в которой есть класс с полем, являющимся ссылкой на одномерный целочисленный массив. У класса есть...

Васильев C# Глава 7 задача 8 (Просьба объяснить формулировку(задача внутри)
Текст задачи Напишите программу с классом, у которого есть текстовое поле. Значение текстовому полю присваивается при создании объекта...

Задача со строками. Задача находится на фотке, которая прикреплена к сообщению
Фотку прикрепил к сообщению. П.5.4. Правил Запрещено создавать темы с бессмысленными названиями вроде "Помогите!",...

Задача при создание нового лида выводится задача от несущ.пользователя Б24
При создание нового Лида Выходит уведомление от пользователя которого нету в компаний. Как поменять пользователя???


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru