Cod sursa(job #485998)

Utilizator iulian93iul iul iulian93 Data 20 septembrie 2010 12:15:01
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include<stdio.h>
int n,sol[9];
void bkt(int);
bool valid(int);
void afisare();
int main()
{
	freopen("permutari.in","r",stdin);
	freopen("permutari.out","w",stdout);
	scanf("%d",&n);
	bkt(1);
	return 0;
}
void bkt (int p)
{
	if(p==n+1)
	{
		afisare();
		return;
	}
	for (int i=1; i<=n; ++i)
	{
		sol[p]=i;
		if (valid(p))
			bkt (p+1);
	}
}
bool valid (int p)
{
	for (int i=1; i<p; ++i)
		if (sol[i]==sol[p]) return false;
	return true;
}
void afisare()
{
	for (int i=1; i<=n; ++i)
		printf("%d ", sol[i]);
    printf("\n");
}