#include using namespace std; #include using namespace boost::multiprecision; using bint = cpp_int; template bool cmin(T &a, U b) { return a > b && (a = b, true); } template bool cmax(T &a, U b) { return a < b && (a = b, true); } signed main() { cin.tie(nullptr); ios_base::sync_with_stdio(false); long N, M; cin >> N >> M; N %= M * 1000; N /= 1000; auto com = [&](auto n, auto k) { bint ret = 1; for (int i = 0; i < k; i++) { ret *= n - i; ret /= i + 1; } return ret; }; cout << com(M, N) % 1000000000 << "\n"; }