Cod sursa(job #2249664)

Utilizator AlexutAlex Calinescu Alexut Data 30 septembrie 2018 09:56:57
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
#include <fstream>

using namespace std;

const int maxL = 40321;
int n, x[maxL];
ifstream in("permutari.in");
ofstream out("permutari.out");

int valid(int k)
{
    for(int i = 1; i < k; i++)
        if(x[k] == x[i])
            return 0;
    return 1;
}

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

void backt(int k)
{
    if(k <= n)
        for(int v = 1; v <= n; v++)
        {
            x[k] = v;
            if(valid(k))
                backt(k + 1);
        }
    else afis(n);
}

int main()
{
    in >> n;
    backt(1);
    return 0;
}