Cod sursa(job #387392)

Utilizator HoriaClementHoriaC HoriaClement Data 27 ianuarie 2010 15:50:07
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <cstdio>

int n,sol[16];

bool marcat[16];

void afisare()
{
	for(int i=1 ; i<=n ; ++i)
		printf("%d ",sol[i]);
	printf("\n");
}

/*
bool valid(int p)
{
	for(int i=1 ; i<p ; ++i)
		if(sol[i] == sol[p])
			return false;
	return true;
}
*/

void bkt(int p)//completeaza elem de pe pozitia p din sol
{
	if(p==n+1)//daca poz pe care ar urma sa o completez ar fi n+1,ar insemna ca am completat deja n, deci am o perm
	{
		afisare();
		return;
	}
	for(int i=1 ; i<=n ; ++i)//parcurg valorile pe care le poate lua sol[p]
		if(!marcat[i])
		{
			sol[p] = i;
			marcat[i] = true;
			bkt(p+1);
			marcat[i] = false;
		}
}

int main()
{
	freopen("permutari.in","r",stdin);
	freopen("permutari.out","w",stdout);
	scanf("%d",&n);
	bkt(1);
	return 0;
}