제출 #652919

#제출 시각아이디문제언어결과실행 시간메모리
652919tamthegod캥거루 (CEOI16_kangaroo)C++14
100 / 100
24 ms31684 KiB
// Make the best become better // No room for laziness #include<bits/stdc++.h> #define ll long long #define int long long #define pb push_back #define fi first #define se second using namespace std; const int maxN = 2e3 + 5; const int mod = 1e9 + 7; const ll oo = 1e18; int n; int cs, cf; int f[maxN][maxN]; void ReadInput() { cin >> n >> cs >> cf; } void Solve() { f[0][0] = 1; for(int i=1; i<=n; i++) { for(int j=1; j<=n; j++) { if(i == cs || i == cf) { f[i][j] = f[i - 1][j - 1] + f[i - 1][j]; f[i][j] %= mod; } else { f[i][j] = f[i - 1][j + 1] * j; f[i][j] += f[i - 1][j - 1] * (j - (i > cs) - (i > cf)); f[i][j] %= mod; } } } cout << f[n][1]; } int32_t main() { ios_base::sync_with_stdio(false); cin.tie(NULL); ReadInput(); Solve(); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...