Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/30: Рейтинг темы: голосов - 30, средняя оценка - 4.67
 Аватар для Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20

Рекурсивная процедура печати всех перестановок из n символов

03.11.2009, 21:32. Показов 6563. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
"Написать процедуру печати всех перестановок из n символов"
методом рекурсии

непривычно и трудно в C++
помогите пожалуйста!
=(((
1
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.11.2009, 21:32
Ответы с готовыми решениями:

Процедура печати всех перестановок из n символов - перевод с C++
Есть программа работает как мне надо, только она на С++. А переделать не получается. Может кто поможет...плиззз #include...

Рекурсивная процедура для печати в обратном порядке текста, заданного во входном файле
Разработать рекурсивную процедуру для печати в обратном порядке текста, заданного во входном файле (за текстом следует точка)

Схема алгоритма получения (печати) всех перестановок из n чисел
Помогите пожалуйста, нужна блок схема и код алгоритма получения (печати) всех перестановок из n чисел.Сам додумать не могу и уже не хватает...

15
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
03.11.2009, 21:47
http://algolist.manual.ru/math... ations.php
правда тут на паскале )
2
 Аватар для Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
03.11.2009, 22:12  [ТС]
так на паскале это одно дело!
именно C++!
=)
1
Заблокирован
03.11.2009, 22:53
если маленькое n то можно так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
using std::cin;
using std::cout;
using std::endl;
void f(int n,int m){
    int k=n-1;
    if(!n) cout<<m<<endl;
    while(n){
        (m*=10)+=n;
        f(k,m);
        (m-=n)/=10;
        n--;
    }
}
int main(){
    int n;
    cin>>n;
    f(n,0);
    cin.get(),cin.get();
    return 0;
}
для большого n надо переменную m заменить на массив.
1
 Аватар для ООП
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 13
03.11.2009, 23:46
Привет земеля!!!
Ты точно всем нос утрешь такой прогой: открываем Borland C++ Builder, кидаем на форму ListBox (у него ставим Sort в true) и Button и пишем следующие (соответственно создавая нужные события и функции в заголовчном)
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
25
26
27
28
29
30
31
32
33
34
35
36
void __fastcall TForm1::Button1Click(TObject *Sender)
{
        ListBox1->Clear();
        TStringList *l = new TStringList();
        l->Delimiter = ' ';
        l->Add("1"); l->Add("2"); l->Add("3");
        l->Add("4"); l->Add("5"); l->Add("6");
 
        // это можно убрать
        AnsiString text = l->DelimitedText;
        ListBox1->Items->Add(text);
 
        next(l, fac(l->Count,l->Count));
        Button1->Caption = (AnsiString)ListBox1->Items->Count;
}
//---------------------------------------------------------------------------
 
 
void __fastcall TForm1::next(TStringList * lst, int pos)
{
        randomize();
        bool n = false;
        while(!n){
        lst->Exchange(random(lst->Count), random(lst->Count));
        AnsiString text = lst->DelimitedText;
        if(ListBox1->Items->IndexOf(text) < 0)
                {ListBox1->Items->Add(text); n = true;}
        }
        if(pos > 2) next(lst, --pos);
        else return;
}
 
int __fastcall TForm1::fac(int f, int n)
{
        return --n ? fac(f * n, n) : f;
}
1
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
03.11.2009, 23:59
Если я правильно понял, то тебе надо найти n-факториал методом рекурсии. Если да, то это так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream.h>
#include <conio.h>
 
double factorial(int N)
{
return ( (N<0) ? 0 : ((N<=1) ? 1 : N*factorial(N-1)) );
}
 
int main()
{
    int n;
    cin>>n;
    cout<<factorial(n);
             getch();
 
    return 0;
}
0
 Аватар для Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
04.11.2009, 00:12  [ТС]
нет, мне не факториал надо найти, а просто перебор :
например: 123, 132, 213,231,312,321, и вывести на экран

Добавлено через 2 минуты
а что значит " ? " в 6-ой строчке?
я просто в языке С++ вообще полный ноль((((
0
Босс
 Аватар для sheka
161 / 126 / 10
Регистрация: 03.06.2009
Сообщений: 750
04.11.2009, 00:15
это выбор из двух условий, если не ошибаюсь.
условие1 ? условие2 : условие3
если условие1 справедливо, выполняется условие2, иначе условие3
0
 Аватар для manfeese
133 / 132 / 29
Регистрация: 04.01.2009
Сообщений: 415
04.11.2009, 00:29
sheka прав. Это сокращенная запись условного оператора.

Добавлено через 5 минут
Вот вариант, но без рекурсии Перебор возможных комбинаций символов
1
 Аватар для ООП
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 13
04.11.2009, 01:00
Факториал все равно может понадобиться: n! - это число всех возможных вариантов. функция fac у меня как раз его и возвращает.

Янчик, у меня несколько шуточный пример (зато он работает и над ним не надо думать долго) для 6 чисел - хорошо, для 7 - уже плохо. Можно более оптимизированно сделать, чем просто ставить туда рандомные значения.

То, что я пометил в комментарии, что можно удалить, лучьше не удалять , но если все же удалишь, то нужно исправить строку в функции next с if(pos > 2) next(lst, --pos); на if(pos > 1) next(lst, --pos); а то один какой-то вариант не досчитает.

Добавлено через 2 минуты
а если не удалять, то, наверное, будет работать чуть быстрее
0
Эксперт С++
 Аватар для valeriikozlov
4728 / 2549 / 757
Регистрация: 18.08.2009
Сообщений: 4,568
04.11.2009, 09:39
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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#include <iostream.h>
void f(int n, int temp[]){
    int i, j;
    bool fl=false;
    for(i=0; i<n-1; i++)
        for(j=i+1; j<n; j++)
            if(temp[i]==temp[j])
                fl=true;
    if(!fl)
    {
        for(i=0; i<n; i++)
            cout<<temp[i];
        cout<<endl;
    }
    temp[0]++;
    for(i=0; i<n; i++)
        if(temp[i]>n)
        {
            temp[i]=1;
            temp[i+1]++;
        }
    if(temp[n-1]==n && temp[n-2]==n)
        return;
    f(n, temp);
    return;
}
 
int main(){
        int n, i, *temp;
        cout<<"Vvedite n: ";
        cin>>n;
        temp=new int[n];
        for(i=0; i<n; i++)
            temp[i]=n-i;
        f(n, temp);
        cin.get(),cin.get();
        return 0;
}
1
Заблокирован
04.11.2009, 11:37
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
using std::cin;
using std::cout;
using std::endl;
void f(int n,int m){
    if(!n) 
        cout<<m<<endl;
    for(int k=n-1;n;n--)
        f(k,m*10+n);
}
int main(){
        int n;
        cin>>n;
        f(n,0);
        cin.get(),cin.get();
        return 0;
}
0
6 / 6 / 0
Регистрация: 29.09.2009
Сообщений: 41
04.11.2009, 15:04
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
25
26
27
28
29
30
31
32
33
#include <stdio.h>
#include <conio.h>
 
int k=1;
 
int func (char * mas, int n,int h)
{
   char ch;
   int i;
   if (n==h)
      {
         printf ("%4d %s\n",k,mas);
         k++;
         return 1;
      }
   for (i=h;i<n;i++)
      {
         ch=mas[h];
         mas[h]=mas[i];
         mas[i]=ch;
         func (mas,n,h+1);
         mas[i]=mas[h];
         mas[h]=ch;
      }
}
 
int main ()
{
   char m[]="12345";
 
   func (m,5,0);
   getch();
}
1
 Аватар для Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
09.11.2009, 23:29  [ТС]
что значит "неразрешённый внешний символ"?
0
6 / 6 / 0
Регистрация: 29.09.2009
Сообщений: 41
11.11.2009, 20:38
Можно про ошибку подробнее.
Кстати сейчас увидил - ошибочка в формировании массива.
Выводится как строка, а формируется как массив символов.
Необходимо что бы в конце массива был 0.
возможно и ошибка из-за этого

C
1
2
3
4
5
6
7
8
9
10
#include <string.h>
int main ()
{
   char m[20];
 
   strcpy (m,"12345");
 
   func (m,strlen(m),0);
   getch();
}
0
 Аватар для Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
07.12.2009, 18:12  [ТС]
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
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include <vcl.h>
#include "iostream.h"
 
int* ar;
int n;
 
void func(int m)
{
for(int i=1;i<=n;i++)
{
int k=0;
for(int j=0;j<n;j++)
{
if(ar[j]==i)
{
k = 1;
break;
}
}
 
if(k==0)
{
ar[n-m] = i;
if(m==1)
{
for(int i=0;i<n;i++)
cout<<ar[i];
cout<<endl;
ar[n-m]=0;
return;
}
else
func(m-1);
}
 
}
ar[n-m]=0;
return;
}
 
int main(int argc, char* argv[])
{
cout<<"Input n:"<<endl;
cin>>n;
 
ar = new int[n];
for(int i=0;i<n;i++)
ar[i]=0;
cout<<endl;
func(n);
 
cout<<endl;
system("pause");
return 0;
}
Добавлено через 12 секунд
ура! всё сделала!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.12.2009, 18:12
Помогаю со студенческими работами здесь

Перебор всех перестановок символов в строке
Помогите решить задачу пожалуйста. Напишите функцию с прототипом void permute (const string &amp; str ) ; которая выводит на...

Поиск всех перестановок символов из строки (0..9)..пожалуйста помогите!!!
ведь наверняка ктото уже писал такие алгоритмы будь то на олимпеаде или где ещё!!!..... мне в универе позарез надо это я незнаю как даже...

Разработайте алгоритм для вывода всех возможных перестановок символов в строке
Разработайте алгоритм для вывода всех возможных перестановок символов в строке (считайте, что все символы используются только один раз).

Генерация всех перестановок n-элементного множества за минимальное количество перестановок (Алгол60 -> Дельфи)
Искал по книгам код для данной задачи: Разработать алгоритм генерации всех перестановок n-элементного множества за минимальное количество...

Рекурсивная генерация перестановок
{ рекурсивные алгоритмы: генерация перестановок } const n = 3; { количество элементов в перестановке} var a:array of integer; ...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки 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. На борту пять. . .
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера 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