제출 #1094334

#제출 시각아이디문제언어결과실행 시간메모리
1094334blacktulipArt Exhibition (JOI18_art)C++17
30 / 100
2271 ms262144 KiB
#include <bits/stdc++.h> using namespace std; typedef long long lo; #define fi first #define se second #define endl "\n" #define pb push_back #define int long long #define fio() ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL) #define FOR for(int i=1;i<=n;i++) #define mid ((start+end)/2) #define ort ((bas+son)/2) #define _ << " " << const lo inf = 1000000000; const lo li = 305; const lo mod = 1000000007; int n,m,a[li],k,flag,t,b[li],dp[li][li][li]; int cev; string s; vector<int> v; inline int f(int i,int maxi,int mini){ int cevap=-1000000000000000000; if(i>n){ return -(a[maxi]-a[mini]); } if(~dp[i][maxi][mini])return dp[i][maxi][mini]; cevap=max(cevap,f(i+1,maxi,mini)); int tmax=maxi; if(maxi==0 || a[i]>a[maxi])tmax=i; int tmin=mini; if(mini==0 || a[i]<a[mini])tmin=i; cevap=max(cevap,f(i+1,tmax,tmin)+b[i]); //~ cout<<maxi _ mini _ i <<endl; return dp[i][maxi][mini]=cevap; } int32_t main(void){ fio(); cin>>n; memset(dp,-1,sizeof(dp)); for(int i=1;i<=n;i++){ cin>>a[i]>>b[i]; } cout<<f(1,0,0)<<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...