#include "message.h" #include "futbol.h" #include<iostream> using namespace std; const int CHUNK = 10000000; long long mul_mod(long long a, long long b, long long c) { return a * b; } long long add_mod(long long a, long long b, long long c) { return a + b; } int main() { int id = MyNodeId(); long long n = GetN(); long long k = GetK(); long long p = GetP(); long long strong = 1; if (id == 0) { long long result = 1; long long n_strong = 1; for (int i = 1; i <= n; i++) { n_strong = mul_mod(n_strong, i, p); } while (k > 0) { long long k_strong = 1; for (int i = 1; i <= k; i++) { k_strong = mul_mod(k_strong, i, p); } long long nk_strong = 1; for (int i = 1; i <= (n - k); i++) { nk_strong = mul_mod(nk_strong, i, p); } long long result_strong = n_strong / (k_strong * nk_strong); result = add_mod(result, result_strong, p); k--; } cout << result%p; } else { } return 0; }
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 | #include "message.h" #include "futbol.h" #include<iostream> using namespace std; const int CHUNK = 10000000; long long mul_mod(long long a, long long b, long long c) { return a * b; } long long add_mod(long long a, long long b, long long c) { return a + b; } int main() { int id = MyNodeId(); long long n = GetN(); long long k = GetK(); long long p = GetP(); long long strong = 1; if (id == 0) { long long result = 1; long long n_strong = 1; for (int i = 1; i <= n; i++) { n_strong = mul_mod(n_strong, i, p); } while (k > 0) { long long k_strong = 1; for (int i = 1; i <= k; i++) { k_strong = mul_mod(k_strong, i, p); } long long nk_strong = 1; for (int i = 1; i <= (n - k); i++) { nk_strong = mul_mod(nk_strong, i, p); } long long result_strong = n_strong / (k_strong * nk_strong); result = add_mod(result, result_strong, p); k--; } cout << result%p; } else { } return 0; } |