Cod sursa(job #2194398)

Utilizator PushkinPetolea Cosmin Pushkin Data 13 aprilie 2018 10:40:09
Problema Submultimi Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.89 kb
#include <iostream>
#include <bits/stdc++.h>
#include <fstream>
using namespace std;
ifstream f("submultimi.in");
ofstream g("submultimi.out");
int n, p, k;
vector<int> v;
void rd()
{
    f>>n;
    v.resize(n+1);
}
void afis()
{
    for(int i=1;i<=p;i++)
        g<<v[i]<<' ';
    g<<'\n';
}
bool valid(int k)
{
    return(v[k]>v[k-1]);
}
void BKT()
{
    k=1;
    v[k]=0;
    while(k>0)
    {
        while(k<=p&&v[k]<n-p+k)
        {
            v[k]++;
            if(valid(k))
            {
                if(k==p)
                    afis();
                else
                {
                    k++;
                    v[k]=v[k-1];
                }
            }
        }
        k--;
    }
}
void submult()
{
    for(p=1;p<=n;p++)
        BKT();
}
int main()
{
    rd();
    submult();
    f.close();
    g.close();
    return 0;
}