Cod sursa(job #1012413)
Utilizator | Data | 18 octombrie 2013 22:04:16 | |
---|---|---|---|
Problema | Submultimi | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.65 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("submultimi.in");
ofstream fout("submultimi.out");
int a[20],n;
void afisare(int k)
{
int i;
for(i=1;i<=k;i++)
fout<<a[i]<<" ";
fout<<"\n";
}
bool valid(int k)
{
int i;
for(i=1;i<k;i++)
if(a[i]==a[k])
return false;
return true;
}
void bak(int k)
{
int i;
for(i=a[k-1];i<=n;i++)
{
a[k]=i;
if(valid(k))
{
afisare(k);
if(k<n)
bak(k+1);
}
}
}
int main()
{
fin>>n;
a[0]=1;
bak(1);
return 0;
}