Cod sursa(job #709755)

Utilizator stefaniaaStefania Aungurencei stefaniaa Data 8 martie 2012 16:15:56
Problema Generare de permutari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <fstream>
using namespace std;
ifstream f("permutari.in");
ofstream g("permutari.out");
int n,i,k,as,ev;
int st[13];
void init()
{
	st[k]=0;
}
int succesor()
{
	if (st[k]<n)
	{
		st[k]++;
		return 1;
	}
	else return 0;
}
int valid()
{
	for (i=1;i<k;i++)
		if (st[k]==st[i]) return 0;
	return 1;
}
int solutie()
{
	return (k==n);
}
void tipar()
{
	for (i=1;i<=n;i++)
		g<<st[i]<<' ';
	g<<'\n';
}
void back()
{
	k=1;
	init();
	while (k)
	{
		as=1; ev=0;
		while (as && !ev)
		{
			as=succesor();
			if (as) ev=valid();
		}
		if (as)
		{
			if (solutie()) tipar();
			else 
			{
				k++;
				init();
			}
		}
		else k--;
	}
}
int main()
{
	f>>n;
	back();
	f.close();
	g.close();
	return 0;
}