Pagini recente » Cod sursa (job #2442425) | Istoria paginii utilizator/evghenii_beriozchin | Cod sursa (job #986945) | Atasamentele paginii Viata de dupa olimpiade (II) - Industria de tehnologie | Cod sursa (job #2105066)
#include <cstdio>
using namespace std;
int n,x[9];
void init(int k)
{
x[k]=0;
}
int succ(int k)
{
if(k<=n && x[k]<n)
{
x[k]++;
return 1;
}
else
return 0;
}
int valid(int k)
{
int i;
for(i=1;i<k;i++)
if(x[i]==x[k])
return 0;
return 1;
}
int solutie(int k)
{
if(k==n)
return 1;
else
return 0;
}
void afis(int k)
{
int i;
for(i=1;i<=n;i++)
printf("%d ",x[i]);
printf("\n");
}
void back()
{
int i,k;
k=1;
init(k);
while(k>0)
{
i=0;
while(!i && succ(k))
if(valid(k))
i=1;
if(!i)
k--;
else
if(solutie(k))
afis(k);
else
init(++k);
}
}
int main()
{
freopen("permutari.in","r",stdin);
freopen("permutari.out","w",stdout);
scanf("%d\n",&n);
back();
return 0;
}