Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
184 / 72 / 35
Регистрация: 09.05.2022
Сообщений: 387

Вывести все перестановки символов заданной строки

02.02.2023, 15:07. Показов 2084. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Перестановки
Дана строка, состоящая из M попарно различных символов. Вывести все перестановки
символов данной строки.
Ограничения: 2 ≤ M≤ 8, символы - буквы латинского алфавита и цифры.
Ввод: В первой строке файла находится исходная строка.
Вывод: В первой строке вывести количество перестановок, в следующих строках вывести
в каждой строке по одной перестановке. Перестановки можно выводить в любом порядке.
Повторений и строк, не являющихся перестановками исходной, быть не должно.

Примеры:
-------------
INPUT.TXT
AB

OUTPUT.TXT
2
AB
BA
-------------
INPUT.TXT
IOX

OUTPUT.TXT
6
XOI
OIX
IXO
XIO
OXI
IOX
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.02.2023, 15:07
Ответы с готовыми решениями:

Вывести все перестановки символов данной строки
Дана строка, состоящая из M попарно различных символов. Вывести все перестановки символов данной строки. Ввод В первой строке файла...

Вывести все перестановки символов строки
Дана строка, состоящая из N символов. Требуется вывести все перестановки символов данной строки. Входной файл INPUT.TXT содержит строку,...

Вывести все перестановки символов данной строки
Здравствуйте! Условие задачи: Дана строка, состоящая из N (1 ≤ N ≤ 8) попарно различных символов. Требуется вывести все перестановки...

7
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6208 / 2905 / 1044
Регистрация: 01.06.2021
Сообщений: 10,707
03.02.2023, 09:54
Лучший ответ Сообщение было отмечено Royal_X как решение

Решение

Самый простой в написании код для перестановок выглядит так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
#include <string>
#include <algorithm>
#include <cmath>
 
int main()
{
    std::string s {"XOI"};
    std::cout << std::tgamma(s.length() + 1.) << '\n';
    std::sort(s.begin(), s.end());
    do
        std::cout << s << '\n';
    while (std::next_permutation(s.begin(), s.end()));
}
Примечания:
1) Конечно, можно написать код и без STL, но смысла в оптимизации не вижу, ибо по условию у тебя максимум 8 символов в строке, а это всего лишь 8! = 40320 перестановок. Да и при самой лучшей оптимизации полагаю, что будет O(n*n!), учитывая ещё и вывод.
2) Вместо использования функции tgamma из <cmath> можешь написать функцию для вычисления факториала. Подойдёт даже самая простая рекурсивная функция, ведь считать придется макс. 8!.
1
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
03.02.2023, 11:10
Цитата Сообщение от Royal_X Посмотреть сообщение
Самый простой в написании код для перестановок выглядит так:
но не в понимании. Ну написал в коде next_permutation, а какой алгоритм-то?
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6208 / 2905 / 1044
Регистрация: 01.06.2021
Сообщений: 10,707
03.02.2023, 11:26
Kuzia domovenok, одна из возможных реализации этого алгоритма (код взят из инета):
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
template<class BidirIt>
bool next_permutation(BidirIt first, BidirIt last)
{
  auto r_first = std::make_reverse_iterator(last);
  auto r_last = std::make_reverse_iterator(first);
  auto left = std::is_sorted_until(r_first, r_last);
  if(left != r_last){
    auto right = std::upper_bound(r_first, left, *left);
    std::iter_swap(left, right);
  }
  std::reverse(left.base(), last);
  return left != r_last;
}
Kuzia domovenok, там писать без STL задача на пару минут. Пусть ТС сам напишет, если не устраивает. Но в условии не сказано, что нельзя использовать <algorithm>.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
03.02.2023, 11:44
Цитата Сообщение от Royal_X Посмотреть сообщение
Kuzia domovenok, там писать без STL задача на пару минут. Пусть ТС сам напишет, если не устраивает.
ну, не сказал бы, что всё очевидно, даже ты взял из интернета. Я б сказал, у меня ушло полчаса.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <iostream>
#include <string>
#include <algorithm>
 
int main()
{
    std::string s = "1234";
    std::sort(s.begin(), s.end());
    std::cout << s << std::endl;
    while (1) {
        int i = s.size() - 1;
        while (i > 1 && s[i] < s[i - 1])
            --i;        
        int j = s.size() - 1;
        while (s[i-1] > s[j]) {
            --j;
            if (!j) return 0;
        }
        std::swap(s[i-1], s[j]);
        for (int j=0; i+j<s.size()-1-j; ++j)
            std::swap(s[i +j], s[s.size() - 1 - j]);
        std::cout << s << std::endl;
    }
}
Добавлено через 1 минуту
неужели страшные слова
is_sorted_until
upper_bound
reverse
Нужны новичку, который только виды сортировок начинает учить?
0
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6208 / 2905 / 1044
Регистрация: 01.06.2021
Сообщений: 10,707
03.02.2023, 11:58
Kuzia domovenok, а зачем новичку знать, как работает next_permutation? Тут два варианта: либо условие позволяет использовать string, algorithm, либо нужно писать код без всего этого. Если первый вариант, то мой код подходит, равно как подходит и ваш. Но если второй вариант, то тогда нужно писать, используя массив char и только обычные циклы. И в этом случае и ваш код не подходит.
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
03.02.2023, 12:18
Цитата Сообщение от Royal_X Посмотреть сообщение
Kuzia domovenok, а зачем новичку знать, как работает next_permutation?
1)
а зачем если он настолько нович0к, что алгоритмов не знает, вообще тогда решать задачи на алгоритм перестановок?
Зачем начинают изучать программирования с сортировки пузырьком? Есть же библиотека!
А потому что первая задача в программировании не научить набору ключевыхслов и не научитьгуглить кодв справке,а научить именно ИЗОБРЕТАТЬ! Изобретать алгоритмы!
Потому что этой задачй можно заниматься и без ширины знаний STL и.т.п. Только зная синтаксис массивов и циклов ужеможноотходить от изучения языковыхфич и заваливать новичков сотней алгоритмов сортировокдля саморазбора
2)
На мой взгляд, алгоритмы тем и замечательны, что до них любой нов. может и сам додуматься, а вот использование библиотеки требует очень и очень глубоких знаний С++. Что там со знанием итераторов, стандартных контейнеров, алгоритмической сложности ихиспользования???
1
Эксперт функциональных языков программированияЭксперт С++
 Аватар для Royal_X
6208 / 2905 / 1044
Регистрация: 01.06.2021
Сообщений: 10,707
03.02.2023, 12:40
Kuzia domovenok, значит вы понимаете условие так, как я расписал во втором варианте в посте #6. А я писал:
Но если второй вариант, то тогда нужно писать, используя массив char и только обычные циклы. И в этом случае и ваш код не подходит.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.02.2023, 12:40
Помогаю со студенческими работами здесь

Все возможные варианты перестановки символов строки
Дана строка s, состоящая из n символ (n меньше 6) составить все возможные варианты перестановки этих символов (язык C)

Рекурсивная функция: все возможные перестановки символов строки
Дана строка с n элементами. Например abs. Надо выводить все возможные варианты например abs asb bas bsa sab sba. Надо...

Вывести на экран все возможные перестановки введенных ползователем символов
С клавиатуры задается последовательность символов. Написать программу, которая выводит на экран все возможные перестановки введенных...

Вывести на экран все возможные перестановки введенных символов. Где ошибка?
С клавиатуры задается последовательность символов. Написать программу, которая выводит на экран все возможные перестановки введенных...

Дана строка, состоящая из М символов. Вывести все перестановки символов данной строки
Помогите пожалуйста с решением задачи. (Pascal) Дана строка, состоящая из М символов. Вывести все перестановки символов данной строки. ...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru