找出所有modm=0的区间的个数,再每两个区间之间都可以分开这个串
假设区间数为n最后答案就是
#include<bits/stdc++.h>
#define p 1000000007
using namespace std;
char s[300001];
int n,m,ans,now;
int main()
{
scanf("%d%d%s",&n,&m,s);
for(int i=0;i<n;i++)
{
now=(now*10+s[i]-'0')%m;
if(!now)ans=(ans==0?1:ans*2%p);
}
now?puts("0"):printf("%d",ans);
}