// 基本テンプレート (縮小版) #include using namespace std; #define rep(i,a,n) for(int (i)=(a); (i)<(n); (i)++) #define repq(i,a,n) for(int (i)=(a); (i)<=(n); (i)++) #define repr(i,a,n) for(int (i)=(a); (i)>=(n); (i)--) #define int long long template void chmax(T &a, T b) {a = max(a, b);} template void chmin(T &a, T b) {a = min(a, b);} template void chadd(T &a, T b) {a = a + b;} typedef pair pii; typedef long long ll; constexpr ll INF = 1001001001001001LL; constexpr ll MOD = 1000000000LL; ll comb[10001][10001]; signed main() { rep(i,0,10001) comb[i][0] = 1; rep(i,1,10001) repq(j,1,i) { comb[i][j] = (comb[i-1][j-1] + comb[i-1][j]) % MOD; } int N, M; cin >> N >> M; N /= 1000; N %= M; cout << comb[M][N] << endl; return 0; }