Cod sursa(job #738526)

Utilizator drobertDumitru Robert drobert Data 20 aprilie 2012 18:34:58
Problema Submultimi Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.84 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("submultimi.in");
ofstream g("submultimi.out");
int st[17],i,j,n,k,p;
void init (int k)
{
	st[k]=0;
}
int succesor (int k)
{
	if (st[k]<n)
	{
		st[k]++;
		return 1;
	}
	else return 0;
}
int valid(int k)
{
	int ev=1;
	for (i=1;i<k-1 && ev!=0;i++)
		if (st[k]==st[i])
			ev=0;
	return ev;
}
int solutie (int k)
{
	return k==p+1;
}
void tipar()
{
	for (i=1;i<=p;i++)
		g<<st[i]<<" ";
	g<<'\n';
}
int sort(int k)
{
	int ok=1;
	for (i=2;i<=k && ok!=0;i++)
		if (st[i-1]>=st[i])
			ok=0;
	return ok;
}
void back(int k)
{
	if (solutie(k))
		tipar();
	else
	{
		init(k);
		while (succesor(k))
			if (valid(k) && sort(k))
				back(k+1);
	}
}
int main ()
{
	f>>n;
	for (p=1;p<=n;p++)
		back(1);
	return 0;
	f.close();
	g.close();
}