Pagini recente » Cod sursa (job #1385031) | Cod sursa (job #1321674) | Cod sursa (job #1225650) | Cod sursa (job #1625730) | Cod sursa (job #283033)
Cod sursa(job #283033)
#include<fstream.h>
int a,b,m,n,nr=1,k,j,i,p,x[1001],v[1001][1001];
ifstream f("dusman.in");
ofstream g("dusman.out");
void tipar(int k)
{
int i;
nr++;
if (nr==p) for (i=1;i<=k;i++) g<<x[i]<<" ";
}
int valid(int k)
{
int i;
if (v[x[k]][x[k-1]]) return 0;
for (i=1;i<k;i++)
if (x[k]==x[i]) return 0;
return 1;
}
int sol(int k)
{
if (k==n) return 1;
else return 0;
}
void back()
{
int k;
k=1;
x[k]=0;
while (k>0)
if (x[k]<n)
{
x[k]++;
if (valid(k))
if (sol(k)) tipar(k);
else {k++;x[k]=0;}
}
else k--;
}
int main()
{
f>>n>>p>>m;
for (i=1;i<=m;i++) {f>>a>>b;v[a][b]=v[b][a]=1;}
back();
f.close();
g.close();
return 0;
}