Submission #746925

#TimeUsernameProblemLanguageResultExecution timeMemory
746925vjudge1Calvinball championship (CEOI15_teams)C++14
0 / 100
38 ms65536 KiB
#include <bits/stdc++.h> #define int long long #define endl '\n' using namespace std; int SLV[10011][10011]; int arr[10011]; int slv(int a,int b){ if(b==0)return 1; if(SLV[a][b]!=-1)return SLV[a][b]; return SLV[a][b]=(slv(a+1,b-1)+slv(a,b-1)*a)%1000000007; } signed main(){ ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0); int t=1; // t=INT_MAX; while(t--){ memset(SLV,-1,sizeof SLV); int n=5; cin>>n; for(int a=n;a>=1;a--){ for(int b=0;b<=n;b++){ if(b==0)SLV[a][b]=1; else SLV[a][b]=(SLV[a+1][b-1]+SLV[a][b-1]*a)%1000000007; } } for(int i=0;i<n;i++)cin>>arr[i]; int ans=1; int mx=0; for(int i=0;i<n;i++){ for(int w=1;w<arr[i];w++)ans+=SLV[max(mx,w)][n-i-1]; mx=max(mx,arr[i]); ans%=1000000007; } cout<<ans<<endl; } } /* 1 1 1 1 1 1 1 2 1 1 2 1 1 1 2 2 1 1 2 3 1 2 1 1 1 2 1 2 1 2 1 3 1 2 2 1 1 2 2 2 1 2 2 3 1 2 3 1 1 2 3 2 1 2 3 3 1 2 3 4 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...