Распечатать перестановки с условием01.03.2017, 17:57. Показов 1383. Ответов 8
Метки нет (Все метки)
Даны цифры 1 2 3 4 5 6. Требуется распечатать все
перестановки из этих цифр с условием, что 1) 1 стоит левее 2 2) 3 стоит левее 4 3) 5 стоит левее 6 Всего таких перестановок 90 штук. Чтобы был понятно приведу пример попроще для цифр 1 2 3 4 (условия те же) 1 2 3 4 1 3 2 4 1 3 4 2 3 1 2 4 3 1 4 2 3 4 1 2 (тут других вариантов нет) решение Ну очевидно, что на первом месте могут стоять цифры 1 3 5 а на последнем 2 4 6. А вот дальше видимо не обойтись без прямой проверки всех цифр. Может есть код попроще? Буду рад любой подсказке...
0
|
|
| 01.03.2017, 17:57 | |
|
Ответы с готовыми решениями:
8
|
| 01.03.2017, 18:40 | |
Сообщение было отмечено echs как решение
Решение
Вариант 1:
Генерируем все перестановки (6! = 720), проверяем каждую на корректность условия, печатаем если условие выполняется Вариант 2: Берем вместо последовательности 123456, последовательность 113355, генерируем все перестановки в лексикографическом порядке алгоритмом Нарайаны, перестановок будет 6!/2/2/2 = 90 заменяем в последовательности каждую второе число 1,3,5 на единицу больше, выводим на печать полученную перестановку
1
|
|
| 01.03.2017, 18:58 | ||||||
Сообщение было отмечено echs как решение
Решение
Вариант 2:
1
|
||||||
|
oh my god
|
|
| 02.03.2017, 10:03 | |
|
а что значит 6!=720
это чтото вроде 6*5*4*3*2 ? так это называется ?
0
|
|
| 02.03.2017, 10:27 | ||
|
1
|
||
|
oh my god
|
|
| 02.03.2017, 10:31 | |
|
Я к чему спросил, я делал нечто подобное, там были значения от 1 до 9. для того чтобы открыть кодовый замок
именно поэтому мне алгоритм показался знакомый и с полным перебором и половинчатым а это оказывается факториал называется, значит я тоже гений !, потому что в школе не проходил такое ) алгоритм писал опираясь на свой опыт
0
|
|
| 03.03.2017, 14:05 | ||
Сообщение было отмечено echs как решение
РешениеЕсли не прогуливать в школе/институте математику (разделы комбинаторики и теории вероятности), то можно до подобного решения додуматься самостоятельно.
1
|
||
| 03.03.2017, 14:05 | |
|
Помогаю со студенческими работами здесь
9
Распечатать перестановки в лексикографическом порядке Перестановки: чтобы любые две соседние перестановки отличались только порядком двух соседних элементов
Цикл с пред условием и пост условием: табулирование функций Нужна прога с пред условием и пост условием и циклом Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Переходник 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),. . .
|
|
[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 и. . .
|