Cod sursa(job #394038)

Utilizator mihai995mihai995 mihai995 Data 10 februarie 2010 13:45:12
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include<fstream>

using namespace std;

int sol[10],n;
ifstream f("permutari.in");
ofstream o("permutari.out");

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++)
		o<<sol[i]<<" ";
	o<<"\n";
}

void bkt(int p)//completeaza sol[p]
{
	if(p==n+1)
	{
		afisare();
		return;
	}
	for(int i=1 ; i<=n ; ++i)//parcurg val pe care le poate lua sol[p]
	{
		sol[p]=i;
		if(valid(p))//daca sol[p] e compatibil cu sol[1],...,sol[p-1]
			bkt(p+1);
	}
}

int main()
{
	f>>n;
	bkt(1);
	return 0;
}