제출 #760403

#제출 시각아이디문제언어결과실행 시간메모리
760403lalig777Rabbit Carrot (LMIO19_triusis)C++14
63 / 100
95 ms262144 KiB
#include <iostream> #include <vector> #include <algorithm> using namespace std; int main(){ int n, k; cin>>n>>k; vector<vector<int>>dp(n+1, vector<int>(n+1)); vector<int>v(n); for (int i=0; i<n; i++){ cin>>v[i]; if (dp[0][i]!=-1 and v[i]-dp[0][i]<=k) dp[0][i+1]=v[i]; else dp[0][i+1]=-1; }if (dp[0][n]!=-1){ cout<<0<<endl; return 0; }for (int i=1; i<=n; i++){ for (int j=i; j<=n; j++){ int a=-1, b=-1; if (dp[i-1][j-1]!=-1) a=dp[i-1][j-1]+k; if (dp[i][j-1]!=-1 and v[j-1]-dp[i][j-1]<=k) b=v[j-1]; dp[i][j]=max(a, b); }if (dp[i][n]!=-1){ cout<<i<<endl; return 0; } }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...