제출 #681842

#제출 시각아이디문제언어결과실행 시간메모리
681842bin9638캥거루 (CEOI16_kangaroo)C++17
51 / 100
2066 ms126072 KiB
#include<bits/stdc++.h> using namespace std; #define N 2010 #define ll long long #define ii pair<int,int> #define fs first #define sc second #define pb push_back #define iii pair<int,ii> #define int ll #pragma GCC optimize("Ofast") #pragma GCC optimize("inline") #pragma GCC optimize("omit-frame-pointer") #pragma GCC optimize("unroll-loops") const ll mod=1000000007; void selfadd(int&u,int v) { u=(u+v)%mod; } int dp[2][N][N][2],n,S,T; int32_t main() { // freopen("A.inp","r",stdin); // freopen("A.out","w",stdout); ios::sync_with_stdio(0); cin.tie(NULL); cout.tie(NULL); cin>>n>>S>>T; for(int i=S;i<=n;i++) dp[(n&1)][T][i][0]=dp[(n&1)][T][i][1]=1; // 0 <- // 1 -> for(int i=n-1;i>=2;i--) { //memset(dp[(i&1)],0,sizeof(dp[(i&1)])); for(int pos=1;pos<=i;pos++) for(int j=1;j<=i;j++) if(j!=pos) { //0 <- dp[(i&1)][pos][j][0]=dp[((i+1)&1)][pos+1][min(j,pos)][1]; if(j>=pos) selfadd(dp[i&1][pos][j][0],dp[((i+1)&1)][pos][j][1]-dp[((i+1)&1)][pos][pos][1]); //1 -> dp[(i&1)][pos][j][1]=(dp[((i+1)&1)][pos][i+1][0]-dp[((i+1)&1)][pos][max(pos,j)][0])%mod; if(j<=pos) selfadd(dp[(i&1)][pos][j][1],dp[((i+1)&1)][pos+1][pos+1][0]-dp[((i+1)&1)][pos+1][j][0]); selfadd(dp[(i&1)][pos][j][0],dp[(i&1)][pos][j-1][0]); selfadd(dp[(i&1)][pos][j][1],dp[(i&1)][pos][j-1][1]); }else { dp[(i&1)][pos][j][0]=dp[(i&1)][pos][j-1][0]; dp[(i&1)][pos][j][1]=dp[(i&1)][pos][j-1][1]; } } cout<<(dp[0][1][2][0]+dp[0][2][1][1]+mod*mod)%mod; 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...