Pagini recente » Cod sursa (job #2459088) | Cod sursa (job #2459276) | Cod sursa (job #494383) | Cod sursa (job #2656416) | Cod sursa (job #796387)
Cod sursa(job #796387)
#include <fstream>
using namespace std;
ifstream f("permutari.in");
ofstream g("permutari.out");
int x[100],k,n;
void init()
{
x[k]=0;
}
int succesor()
{
if(x[k]<n)
{
x[k]++;
return 1;
}
else return 0;
}
int valid()
{
int ev=1,i;
for (i=1;i<=k-1;i++)
if (x[i]==x[k])
ev=0;
return ev;
}
int solutie()
{
if (k==n) return 1; else return 0;
}
void tipar()
{
int i;
for (i=1;i<=n;i++)
g<<x[i]<<" ";
g<<"\n";
}
int back()
{ int as;
k=1; init();
while (k>0)
{
do {} while ((as=succesor()) && !valid());
if (as)
if (solutie()) tipar();
else
{
k++;
init();
}
else k--;
}
return 0;
}
int main()
{
f>>n;
back();
f.close();
g.close();
return 0;
}