Pagini recente » Cod sursa (job #2333612) | Cod sursa (job #3194463) | Cod sursa (job #1250766) | Cod sursa (job #795162) | Cod sursa (job #788735)
Cod sursa(job #788735)
#include<iostream>
#include<fstream>
using namespace std;
#define bit( x , nr ) ( ( (x) & ( 1 << (nr) ) ) != 0 )
const int NMAX = 18;
const int PMAX = 20;
const int INF = 1<<30;
int cif[10],d[1<<NMAX][PMAX];
void citeste(int &p)
{
long long x;
ifstream f("ratphu.in");
f>>x>>p;
while(x) {
cif[++cif[0]]=x%10;
x=x/10;
}
f.close();
}
int main()
{
int i,j,k,n,p;
citeste(p);
ofstream g("ratphu.out");
n=cif[0];
for(i=1;i<=n;i++)
d[1<<(i-1)][cif[i]%p]++;
for(i=1;i<(1<<n);i++) {
for(j=0;j<=n-1;j++)
if(bit(i,j)==0) {
for(k=0;k<=p-1;k++)
d[i|(1<<j)][(k*10+cif[j+1])%p]+=d[i][k];
}
}
g<<d[(1<<n)-1][0]<<'\n';
g.close();
return 0;
}