Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 23, средняя оценка - 4.78
Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
#1

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

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

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

непривычно и трудно в C++
помогите пожалуйста!
=(((
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.11.2009, 21:32     Рекурсивная процедура печати всех перестановок из n символов
Посмотрите здесь:
C++ Рекурсивная процедура для печати в обратном порядке текста, заданного во входном файле
C++ Поиск всех перестановок символов из строки (0..9)..пожалуйста помогите!!!
C++ рекурсивная функция печати массива
Рекурсивная функция печати массива C++
Рекурсивная подпрограмма печати чисел из файла C++
Рекурсивная процедура вычисления факториала C++
Рекурсивная процедура умножения матриц C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
03.11.2009, 21:47     Рекурсивная процедура печати всех перестановок из n символов #2
http://algolist.manual.ru/maths/comb...rmutations.php
правда тут на паскале )
Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
03.11.2009, 22:12  [ТС]     Рекурсивная процедура печати всех перестановок из n символов #3
так на паскале это одно дело!
именно C++!
=)
rrrFer
Заблокирован
03.11.2009, 22:53     Рекурсивная процедура печати всех перестановок из n символов #4
если маленькое 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 заменить на массив.
ООП
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 13
03.11.2009, 23:46     Рекурсивная процедура печати всех перестановок из n символов #5
Привет земеля!!!
Ты точно всем нос утрешь такой прогой: открываем 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;
}
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
03.11.2009, 23:59     Рекурсивная процедура печати всех перестановок из n символов #6
Если я правильно понял, то тебе надо найти 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;
}
Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
04.11.2009, 00:12  [ТС]     Рекурсивная процедура печати всех перестановок из n символов #7
нет, мне не факториал надо найти, а просто перебор :
например: 123, 132, 213,231,312,321, и вывести на экран

Добавлено через 2 минуты
а что значит " ? " в 6-ой строчке?
я просто в языке С++ вообще полный ноль((((
sheka
Босс
161 / 127 / 7
Регистрация: 03.06.2009
Сообщений: 751
04.11.2009, 00:15     Рекурсивная процедура печати всех перестановок из n символов #8
это выбор из двух условий, если не ошибаюсь.
условие1 ? условие2 : условие3
если условие1 справедливо, выполняется условие2, иначе условие3
manfeese
129 / 128 / 16
Регистрация: 04.01.2009
Сообщений: 415
04.11.2009, 00:29     Рекурсивная процедура печати всех перестановок из n символов #9
sheka прав. Это сокращенная запись условного оператора.

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

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

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

Добавлено через 2 минуты
а если не удалять, то, наверное, будет работать чуть быстрее
valeriikozlov
Эксперт C++
4669 / 2495 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
04.11.2009, 09:39     Рекурсивная процедура печати всех перестановок из n символов #11
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;
}
rrrFer
Заблокирован
04.11.2009, 11:37     Рекурсивная процедура печати всех перестановок из n символов #12
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;
}
Chea
6 / 6 / 0
Регистрация: 29.09.2009
Сообщений: 41
04.11.2009, 15:04     Рекурсивная процедура печати всех перестановок из n символов #13
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();
}
Янчик
2 / 2 / 0
Регистрация: 03.11.2009
Сообщений: 20
09.11.2009, 23:29  [ТС]     Рекурсивная процедура печати всех перестановок из n символов #14
что значит "неразрешённый внешний символ"?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.11.2009, 20:38     Рекурсивная процедура печати всех перестановок из n символов
Еще ссылки по теме:
Рекурсивная процедура вычисления биномиальных коэффициентов C++
C++ Рекурсивная процедура вычисления n-го числа Фибоначчи
C++ Рекурсивная процедура перевода числа из десятичной системы счисления в двоичную
Рекурсивная процедура для вывода на экран цифр натурального числа в обратном порядке C++
Рекурсивная процедура для вывода на экран цифр натурального числа в обратном порядке! C++

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

Или воспользуйтесь поиском по форуму:
Chea
6 / 6 / 0
Регистрация: 29.09.2009
Сообщений: 41
11.11.2009, 20:38     Рекурсивная процедура печати всех перестановок из n символов #15
Можно про ошибку подробнее.
Кстати сейчас увидил - ошибочка в формировании массива.
Выводится как строка, а формируется как массив символов.
Необходимо что бы в конце массива был 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();
}
Yandex
Объявления
11.11.2009, 20:38     Рекурсивная процедура печати всех перестановок из n символов
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru