|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
Перестановки: каждая следующая получается из предыдущей перестановкой двух соседних чисел18.05.2014, 18:47. Показов 4613. Ответов 19
Метки нет (Все метки)
Расскажите пожалуйста как это сделать в СИ#:
Напечатать все перестановки чисел 1....n, чтобы каждая следующая получалась из предыдущей перестановкой двух соседних чисел. Например, при n=3 следует переставлять: 3.21 → 23.1 → 2.13 → 12.3 →1.32 →3.12. Понимаю логически, но в программе не выходит. Заранее спасибо
0
|
|
| 18.05.2014, 18:47 | |
|
Ответы с готовыми решениями:
19
Сколько имеется четырехзначных чисел, у которых каждая следующая цифра меньше предыдущей? Больше предыдущей?
|
|
2444 / 1842 / 406
Регистрация: 15.12.2013
Сообщений: 8,243
|
|
| 18.05.2014, 20:28 | |
|
Кассия, показывайте наработки.
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
||||||
| 19.05.2014, 00:18 | ||||||
Сообщение было отмечено Кассия как решение
Решение
Кассия, похоже на алгоритм генерации перестановок Джонсона - Троттера. Есть реализация с массивчиками:
1
|
||||||
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 19.05.2014, 23:11 [ТС] | |
|
Спасибо большое! теперь буду разбираться и, если можно, задавать вам вопросы. Я тоже делала через массив, но мне мешает точка, которая должна стоять между меняющимися цифрами. Это я не поняла, как делать, у меня типы данных не сходятся.
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
|
| 20.05.2014, 00:09 | |
|
Кассия, не понял - точка нужна или нет? задавайте вопросы, только линкуйте ник в сообщении, чтобы мне пришло уведомление..
1
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 20.05.2014, 23:39 [ТС] | |
|
rRczZZ, спасибо! Точка должна быть расположена там, где намечается перестановка. Так должно быть в идеале.
А у меня с типами данных проблема, я раньше писала в Паскале, там таких проблем нет.
0
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 22.05.2014, 22:09 [ТС] | |
|
rRczZZ, вообще довольно сложный алгоритм решения! Я проще представляла...
А зачем нужна проверка на мобильность? что это такое?
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
|
| 22.05.2014, 22:22 | |
|
Кассия, Вы читали описание алгоритма по ссылке или еще где? Вот еще есть описание со стрелками на русском. Смысл такой - ищем наибольший "мобильный" и меняем местами с соседним. Я, в коде выше, разделил поиск индекса наибольшего мобильного и обмена (с дальнейшими действиями) на две функции, чтобы получить место куда вставлять вашу точку. + инвертировал знаки, чтобы подогнать под ваш пример.
Или Вам нужен именно математический вывод алгоритма?
1
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 22.05.2014, 22:43 [ТС] | |
|
rRczZZ, Спасибо за ссылки.
Мне нужно,вывести все перестановки чисел 1....n, так чтобы каждая следующая получалась из предыдущей перестановкой двух соседних чисел. И точка показывает, какие числа сейчас поменяются. И все... Как менять числа местами я знаю, это понятно. Вы их сначала расположили по возрастанию, а потом меняете по значению? В общем смысл ясен, но у меня выводит ошибку в последних строчках, в методе Join. А зачем нужно строки соединять там?
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
||||||
| 22.05.2014, 23:03 | ||||||
|
Кассия, в моем коде ошибка? в result лежат строки вида "1.23", далее склеиваются со стрелкой. Действительно, не работает в .net 3.5. Попробуйте так:
0
|
||||||
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 22.05.2014, 23:18 [ТС] | |
|
rRczZZ
О все запустилось. Большое спасибо!!! Я смысл поняла и как с точкой быть поняла. Теперь буду делать программу, которая не только 3 цифры меняет, а столько сколько введено n.
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
|||||||||||
| 22.05.2014, 23:32 | |||||||||||
|
Кассия, шикарно. В коде можно менять входной массив как угодно, например, вместо
0
|
|||||||||||
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 24.05.2014, 23:31 [ТС] | |
|
rRczZZ, Да, я это поняла. Еще раз большое спасибо, вы мне очень помогли.
0
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
||||||
| 26.05.2014, 22:47 [ТС] | ||||||
|
rRczZZ, И еще один вопрос, пожалуйста. Я делаю так, чтобы массив заполнялся сам, в зависимости от введенной цифры. То есть ввели 4 - перестановка из 1,2,3,4; ввели 6- из1,2,3,4,5,6 и т.д.
Для этого делаю массив вот так:
0
|
||||||
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
||||||
| 27.05.2014, 00:42 | ||||||
|
Кассия, что-то запутаное там, на копипаст похоже
1
|
||||||
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 27.05.2014, 21:18 [ТС] | |
|
rRczZZ,
Подчеркивает р, (строка 14 и 21) пишет: элемент "р" не существует в текущем контексте. Что нужно добавить?
0
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 03.06.2014, 00:14 [ТС] | |
|
rRczZZ,
Вот только это осталось исправить, не подскажите в чем ошибка? Что нужно добавить, чтобы он воспринимал р?
0
|
|
|
814 / 422 / 169
Регистрация: 08.02.2013
Сообщений: 711
|
|
| 03.06.2014, 00:17 | |
|
Кассия, нужен код в котором требуется исправить
1
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 04.06.2014, 00:23 [ТС] | |
|
rRczZZ, ошибка в том коде, который вы в последний раз мне писали 27.05.2014.
Переменная р в 11, 14 и 25 строчках Добавлено через 2 часа 35 минут rRczZZ, Я уже сама исправила, теперь программа запускается, но какую бы я цифру не ввела, программа не работает. Выводит ошибку - цифра за границей массива. Почему так может быть? А куда в какое место программы нужно добавлять ваш код, который вы прислали 27.05 сообщение в теме #15? И что означает буква р в p.LastSwapIndex, p.Apply(A).ToArray() и других случаях?
0
|
|
|
0 / 0 / 0
Регистрация: 18.05.2014
Сообщений: 38
|
|
| 05.06.2014, 20:07 [ТС] | |
|
rRczZZ, Спасибо Вам, программа уже запускается и все правильно считает!
0
|
|
| 05.06.2014, 20:07 | |
|
Помогаю со студенческими работами здесь
20
Проверить истинность высказывания: Каждая следующая цифра данного трехзначного натурального числа на единицу больше предыдущей Перестановки: чтобы любые две соседние перестановки отличались только порядком двух соседних элементов Найти количество двух соседних положительных чисел и двух соседних чисел разного знака Создать новый файл, каждая строка которого получается из строки исходного файла обратной перестановкой слов
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога
SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
|
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|