#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; } |
English