Pagini recente » Cod sursa (job #975644) | Cod sursa (job #1251473) | Cod sursa (job #1030823) | Cod sursa (job #650923) | Cod sursa (job #1890415)
#include <stdio.h>
using namespace std;
int n,sol[9];
void init(int k)
{
sol[k]=0;
}
int succesor(int k)
{
if(sol[k]<n)
{
sol[k]++;
return 1;
}
return 0;
}
int valid(int k)
{
int i=1;
for(; i<k; i++)
if(sol[i]==sol[k])
return 0;
return 1;
}
int solutie(int k)
{
return k==n;
}
void tipar()
{
int i;
for(i=1; i<=n; i++)
printf("%d ",sol[i]);
printf("\n");
}
void bkt()
{
int k=1;
init(k);
while(k)
{
if(succesor(k))
{
if(valid(k))
{
if(solutie(k))
tipar();
else init(++k);
}
}
else k--;
}
}
int main()
{
freopen("permutari.in","r",stdin);
freopen("permutari.out","w",stdout);
scanf("%d",&n);
bkt();
return 0;
}