Submission #19982

#TimeUsernameProblemLanguageResultExecution timeMemory
19982rlatkddn212괄호 (kriii4_R)C++14
0 / 100
2000 ms2500 KiB
#include <iostream> #include <math.h> #include <queue> #include <vector> #include <string.h> #include <algorithm> #include <stack> #include <map> #include <set> #include <string> #include <tuple> #include <deque> #include <sstream> #include <array> using namespace std; const long long mod = 1000000007; long long f[100001]; long long binomialCoeff(long long n, long long k) { long long res = 1; if (k > n - k) k = n - k; for (int i = 0; i < k; ++i) { res *= (n - i); res /= (i + 1); res %=mod; } return res%mod; } long long catalan(long long n) { long long c = binomialCoeff(2 * n, n)%mod; return c / (n + 1); } int main(){ int n; cin >> n; int k; cin >> k; f[0] = 1; for (int i = 1; i < n; i++){ f[i] = (f[i - 1] * 2)%mod; if (i % 2 == 0){ f[i] -= catalan(i / 2); } f[i] %= mod; } cout << f[n - 1] % mod << endl; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...