#include using namespace std; using ll = long long; #define FOR(i,a,b) for(ll i=(a);i<(b);++i) #define ALL(v) (v).begin(), (v).end() #define p(s) cout<<(s)< void vprint(T &V){ for(auto v : V){ cout << v << " "; } cout << endl; } // パスカルの三角形セット const int N_MAX = 10010; ll pascal[N_MAX][N_MAX] = {}; void calc_pascal(){ FOR(i, 0, N_MAX){ pascal[i][0] = 1; } pascal[1][1] = 1; FOR(i, 2, N_MAX){ for(int j=1; j<=i; j++){ pascal[i][j] = pascal[i-1][j] + pascal[i-1][j-1]; pascal[i][j] %= 1000000000; // 今回の問題用 } } } ll nCr(ll n, ll r){ return pascal[n][r]; } int main(){ cin.tie(0); ios::sync_with_stdio(false); // input ll N, M; cin >> N >> M; N /= 1000; ll rest = N%M; calc_pascal(); ll ans = nCr(M, rest); p(ans); return 0; }