Pagini recente » Cod sursa (job #1840247) | Cod sursa (job #2592571) | Cod sursa (job #1298830) | Monitorul de evaluare | Cod sursa (job #996744)
Cod sursa(job #996744)
#include<fstream>
using namespace std;
ifstream f("ratphu.in");
ofstream g("ratphu.out");
int n,p,i,j,k,v[20],d[1<<19][20];
int main()
{
f>>n>>p;
while(n)
{
v[++v[0]]=n%10;
n/=10;
}
n=v[0];
for(i=1;i<=n/2;++i)
swap(v[i],v[n-i+1]);
for(i=1;i<=n;++i)
d[1<<(i-1)][v[i]%p]=1;
for(i=0;i<(1<<n);++i)
{
for(j=0;j<n;++j)
if(!(i&(1<<j)))
{
for(k=0;k<p;++k)
d[i^(1<<j)][(k*10+v[j+1])%p]+=d[i][k];
}
}
g<<d[(1<<n)-1][0]<<'\n';
return 0;
}