Cod sursa(job #2285523)

Utilizator marcogoldPop Mihali Marco Silviu marcogold Data 18 noiembrie 2018 18:03:53
Problema Generare de permutari Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.89 kb
#include <iostream>
#include <fstream>
using namespace std;


ofstream fo("permutari.out");
ifstream fi("permutari.in");

int sol[10],nivel,n;


void afisare()
{
    for(int i=1;i<=n;i++)
        fo<<sol[i]<<" ";

    fo<<"\n";
}

bool ebun(int nivel)
{
    if(nivel==1)
        return true;

    for(int i=1;i<nivel;i++)
        if(sol[i]==sol[nivel])
        return false;


    return true;

}

bool esol(int nivel)
{

    if(nivel==n)
        return true;

    return false;
}



void BackTracking(int nivel)
{

    for(int i=1;i<=n;i++)
    {
        sol[nivel]=i;

        if(ebun(nivel)==true)
        {
            if(esol(nivel)==true)
                afisare();
            else
                BackTracking(nivel+1);
        }
    }
}

int main()
{
    fi>>n;

    BackTracking(1);

    fo.close();
    fi.close();

    return 0;
}