Cod sursa(job #1499875)

Utilizator delta_wolfAndrei Stoica delta_wolf Data 11 octombrie 2015 11:39:12
Problema Combinari Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include <cstdio>
using namespace std;
int n,p,x[20];
int bun(int k)
{
   if(x[k]<=x[k-1]&&k>1)
   return 0;
    return 1;
}
void back(int k)
{
    int i;
    if(k>p)
    {
        for(i=1;i<=p;i++)
            printf("%d ",x[i]);
        printf("\n");
        return;
    }
    else
    {
        for(i=1;i<=n;i++)
        {
            x[k]=i;
            if(bun(k))back(k+1);
        }
    }
}
void back1(int k,int ultim)
{
    int i;
    if(k>p)
    {
        for(i=1;i<=p;i++)
            printf("%d ",x[i]);
        printf("\n");
        return ;
    }
    else
    {
        for(i=ultim+1;i<=n;i++)
            {
                x[k]=i;
                back1(k+1,x[k]);
            }
    }
}
int main()
{
    freopen("combinari.in","r",stdin);
    freopen("combinari.out","w",stdout);
    scanf("%d%d",&n,&p);
    back1(1,0);
    return 0;
}