제출 #506236

#제출 시각아이디문제언어결과실행 시간메모리
506236rodov캥거루 (CEOI16_kangaroo)C++14
100 / 100
30 ms24012 KiB
#include <bits/stdc++.h> using namespace std; long long n,s,f,k; long long d[5007][5007]; const long long MOD = 1000000007; int main() { cin >> n >> s >> f; d[1][1] = 1; for(int i=2; i<=n; i++) for(int j=1; j<=i; j++) { if(i==s || i==f) d[i][j] = (d[i-1][j-1]+d[i-1][j])%MOD; else { k = j; if(i>s) k--; if(i>f) k--; //if(k<0) cout << k << endl; d[i][j] = (d[i-1][j+1]*j + d[i-1][j-1]*k) % MOD; } } cout << d[n][1] << endl; /* cin >> n; d[1][1] = 1; for(int i=2; i<=n; i++) for(int j=1; j<=i; j++) d[i][j] = d[i-1][j]*(2*j) + d[i-1][j-1]*j + d[i-1][j+1]*j; cout << d[n][1] << endl; */ return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...