Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.65/26: Рейтинг темы: голосов - 26, средняя оценка - 4.65
MiThEoN
 Аватар для VASSUV
466 / 323 / 42
Регистрация: 31.10.2009
Сообщений: 546
Записей в блоге: 2

Выписать все перестановки без повторений

20.02.2013, 22:36. Показов 4949. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Тему копирую из раздела C#, из-за того что на си народу больше.

Есть строка 0,1,2,3,4

и к примеру таблица

C++
1
2
3
int m = 5;
int n = Factorial(m);
int[][] Table = new int[n][5];
Нужно всего то записать в нее все перестановки той строки, в двух циклах, желательно чтоб код был оптимизирован, плевать на время выполнения.

Как не пробовал, не получалось))
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.02.2013, 22:36
Ответы с готовыми решениями:

Перестановки без повторений
привет помогите пожалуйста найти файлик в котором бы были все перестановки из 5 элементов. мне нужно проверить правильно...

Перестановки без повторений
Требуется дописать исключение повторений в коде,спасибо. #include <iostream> using namespace std; const int N =11; int n,a,p; ...

Перестановки без повторений
Как из этого кода сделать конфетку — чтобы не выводились повторения? #include <iostream> using namespace std; string s; ...

3
 Аватар для OstapBender
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
21.02.2013, 04:24
C++
1
2
3
4
5
6
7
8
9
10
11
    int a[] = {1,2,3,4,5};
    int sz = sizeof(a)/sizeof(a[0]);
 
    while (std::next_permutation(a, a+sz)) {
    
        for (int i=0; i<sz; i++)
            std::cout << a[i] << ' ';
 
        std::cout << '\n';
 
    }
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
21.02.2013, 05:10
если человеку надо на другом языке, то ему более интересен непосредственно алгоритм, чем знание крестоотстойных библиотек, т.к. программу, демонстрирующую алгоритм он сам сможет перевести на любой язык, который захочет. А STL привязан к крестам!
Ближе к делу:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void obmen(int* x, int * y){
         *x ^= *y;
         *y ^= *x;
         *x ^= *y;
}
void perestanovki(int* a, int sz){
  int i, tmp;
  if (sz==1){
    sokhrani_perestanovku();
  }
  else
    for(i=1; i<sz; i++){
      obmen(a, a+i);
      perestanovki(a+1, sz-1);
      obmen(a, a+i);
    }
}
1
21.02.2013, 10:34
 Комментарий модератора 
Правила форума п. 5.5: Запрещено размещать тему в нескольких разделах одновременно (кросспостинг), а также дублировать тему в одном разделе.
Закрыто.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.02.2013, 10:34
Помогаю со студенческими работами здесь

Требуется написать перестановки без повторений
#include &lt;iostream&gt; using namespace std; const int N =11; int n,a,p; void f(int k){ if(k == n+1){ for (int i = 1;i...

Сгенерировать всевозможные перестановки N чисел без повторений
Условие задачи: Сгенерировать всевозможные перестановки N чисел без повторений. (Использовать рекурсию, функции и массивы нельзя, выполнять...

Вывести все слова в столбик без повторений
У меня такое задание: Ввести ленту произвольной длины, которую трактовать как текст, в котором слова отделены одним или несколькими...

Получить массив C, содержащий все элементы векторов a и b без повторений
Пусть даны два целочисленных одномерных массива ai и bj (i=1, ..., n ,j=1, ..., k). Получить массив C, содержащий все элементы векто-ров...

В заданном диапазоне чисел найти все сочетания цифр без повторений
Доброго времени суток! Помогите исправить код программы.Вот задание: Для заданных m и n найти все сочетания по m из чисел 1,2,...,n, без...


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

Или воспользуйтесь поиском по форуму:
4
Закрытая тема Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
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, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru