#include using namespace std; const int mod = 1000000000; int dp[10001][10000]; int c_dp(int n,int r){ if(dp[n][r] != -1) return dp[n][r]; if(n < 2*r) return c_dp(n,n-r); if(r == 0){ dp[n][r] = 1; return 1; } if(r == 1){ dp[n][r] = n; return n; } else{ dp[n][r] = (c_dp(n-1,r-1)+c_dp(n-1,r))%mod; return dp[n][r]; } } int main(){ long long N; int M,r,ans; cin >> N >> M; N /= 1000; r = N%M; for(int i=0;i<10001;i++){ for(int j=0;j<10000;j++){ dp[i][j] = -1; } } ans = c_dp(M,r); cout << ans << endl; return 0; }