You are on page 1of 1

#include<iostream>

using namespace std;


int x[100],n,m,nr=0;
void afisare()
{ for(int i=1;i<=n+m;i++)
if(x[i]==1) cout<<"P ";
else cout<<"C ";
cout<<endl;
nr++;
}
int cond(int k)
{
int c=0,p=0,i;
for(i=1;i<=k;i++)
if(x[i]==0) c++;
else p++;
if(p>n || c>m) return 0;
if(k>=3) if(x[k-2]==0 && x[k-1]==1 && x[k]==0) return 0;
return 1;
}
void back(int k)
{ for(int i=1;i>=0;i--)
{
x[k]=i;
if(cond(k))
if(k==n+m) afisare();
else back(k+1);
}
}
int main()
{ cout<<"Introduceti nr de caini: "<<endl;
cin>>n;
cout<<"Introduceti nr de pisici: "<<endl;
cin>>m;
back(1);
cout<<"Numarul de solutii: "<<nr;
return 0;
}

You might also like