Cod sursa(job #1949159)

Utilizator PuiseIovu Vali Puise Data 1 aprilie 2017 19:38:09
Problema Generare de permutari Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include<iostream>
using namespace std;

typedef int stiva[100];
int n;
stiva st;


void init(int k)
{
    st[k]=0;
}
int succesor(int k)
{
    if(st[k]<n)
        {
         st[k]=st[k]+1; return 1;
        }
    else return 0;
}
int valid(int k)
{
    for(int i=1; i<k ;i++)
      {
          if(st[k]==st[i]) return 0;

       }
       return 1;
}
int solutie(int k)
{
    return k==n;
}
void tipar()
{
    for(int i=1;i<=n;i++)
           cout<<st[i]<<" ";
    cout<<endl;
}
void bt(int k)
{
    init(k);
    while (succesor(k))
        if(valid(k))
             if(solutie(k)) tipar();
                 else bt(k+1);
}
int main()
{
    cout<<"n= "; cin>>n;
    bt(1);
    return 0;
}