Cod sursa(job #2296391)

Utilizator anca.sotirAnca Sotir anca.sotir Data 4 decembrie 2018 17:21:20
Problema Generare de permutari Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.06 kb
#include <fstream>
#include <vector>

using namespace std;

ifstream f("permutari.in");
ofstream g("permutari.out");

vector <int> perm;

void afis(int n)
{
    for(int i=1;i<=n;++i)
        g<<perm[i]<<' ';
    g<<'\n';
}

bool ok(int niv)
{
    for(int i=1;i<niv;++i)
        if(perm[niv]==perm[i])
            return false;
    return true;
}

void permutari(int n)
{
    perm.resize(n+1);
    int niv=1;
    perm[1]=0;
    while(niv>0)
    {
        if(perm[niv]<n)
        {
            perm[niv]++;
            if(ok(niv))
            {
                if(niv<n)
                {
                    niv++;
                    perm[niv]=0;
                }
                else
                {
                    afis(niv);
                    perm[niv]=0;
                    niv--;
                }
            }
            else continue;
        }
        else
        {
            perm[niv]=0;
            niv--;
        }
    }
}

int main()
{
    int n;
    f>>n;
    permutari(n);
    return 0;
}