Cod sursa(job #250412)

Utilizator indestructiblecont de teste indestructible Data 30 ianuarie 2009 21:27:05
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <stdio.h>
int n,sol[10];
void init(int k)
{
	sol[k]=0;
}
int succesor(int k)
{
	if (sol[k]<n)
	{
		sol[k]++;
		return 1;
	}
	else
		return 0;
}
int valid(int k)
{
	int i,ev=1;
	for (i=1; i<=k-1; i++)
		if (sol[k]==sol[i])
			ev=0;
	return ev;
}
int solutie(int k)
{
	return k==n+1;
}
void tipar()
{
	for (int i=1; i<=n; i++)
		printf("%d ",sol[i]);
	printf("\n");
}
void back(int k)
{
	if (solutie(k))
		tipar();
	else
	{
		init(k);
		while(succesor(k))
			if (valid(k))
				back(k+1);
	}
}
int main()
{
	freopen("permutari.in","r",stdin);
	freopen("permutari.out","w",stdout);
	scanf("%d",&n);
	back(1);
	return 0;
}