Submission #366656

#TimeUsernameProblemLanguageResultExecution timeMemory
366656EJOI2019AndrewExam (eJOI20_exam)C++14
13 / 100
315 ms134764 KiB
#include<bits/stdc++.h> using namespace std; const int N = 5011; int a[N],b[N]; int dp[N][N]; int mx[N][N]; vector<int> vv; int c; map<int,int> mt; int amount[N*5]; void subtask1356(vector<int> &v,int n,int a[],int b[]) { sort(vv.begin(),vv.end()); for (int i=0; i<vv.size(); i++) { if(mt[vv[i]]==0) { ++c; mt[vv[i]]=c; } } for(int i=1; i<=n; i++) a[i]=mt[a[i]]; for(int i=1; i<=n; i++) b[i]=mt[b[i]]; for(int i=0; i<=n; i++) for(int j=i; j<=n; j++) mx[i][j]=max(mx[i][j-1],a[j]); dp[1][1]=0; if(a[1]==b[1]) dp[1][1]=1; for(int j=1; j<=n; j++) { for(int i=1; i<=c; i++) amount[i]=0; for(int i=j; i<=n; i++) { if(i==j) dp[i][j]=max(dp[i][j],dp[i-1][j-1]+(a[i]==b[i])); ++amount[b[i]]; if(i+1<=n) { if(a[i+1]<=mx[j][i]) { if(b[i+1]==mx[j][i]) dp[i+1][j]=max(dp[i+1][j],dp[i][j]+1); else dp[i+1][j]=max(dp[i+1][j],dp[i][j]); } else { dp[i+1][j]=max(dp[i+1][j], dp[i][j]-amount[mx[j][i]]+amount[mx[j][i+1]]+(b[i+1]==a[i+1])); } } if(j+1<=i) dp[i][j+1]=max(dp[i][j+1],dp[i][j]); } } cout<<dp[n][n]; cout<<"\n"; } int main() { int t; t=1; while(t--) { int n; cin>>n; for(int i=1; i<=n; i++) { cin>>a[i]; vv.push_back(a[i]); } for(int i=1; i<=n; i++) { cin>>b[i]; vv.push_back(b[i]); } subtask1356(vv,n,a,b); } }

Compilation message (stderr)

exam.cpp: In function 'void subtask1356(std::vector<int>&, int, int*, int*)':
exam.cpp:14:16: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   14 | for (int i=0; i<vv.size(); i++)
      |               ~^~~~~~~~~~
#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...