#include #include #include #include #include #include #include #include #define MOD 1000000007 #define ll long long #define ld long double #define FOR(i,a,b) for(ll i=(a);i<(b);i++) #define rep(i,n) FOR(i,0,n) using namespace std; ll withMod2DP(string s, ll _witha, ll _moda,ll _modb){ ll n = s.size(); ll dp[n+1][2][2][_moda][_modb]; // keta,less,forbid, mod _moda, mod _modb rep(i,n+1)rep(j,2)rep(k,2)rep(l,_moda)rep(m,_modb) dp[i][j][k][l][m] = 0; dp[0][0][0][0][0] = 1; rep(keta,n)rep(less,2)rep(ng,2)rep(l,_moda)rep(m,_modb){ int lim = less? 9 : s[keta]-'0'; rep(d,lim+1) (dp[keta+1][less||d> A >> B; ll n = A.size(); rep(i,n){ if(A[n-i-1]=='0')A[n-i-1]='9'; else{ A[n-i-1]-=1; break; } } ll na = withMod2DP(A, 3, 3, 8); ll nb = withMod2DP(B, 3, 3, 8); cout << nb - na << endl; }