Submission #760441

#TimeUsernameProblemLanguageResultExecution timeMemory
760441lalig777Rabbit Carrot (LMIO19_triusis)C++14
63 / 100
98 ms262144 KiB
#include <iostream> #include <algorithm> using namespace std; int main(){ cin.tie(0); ios::sync_with_stdio(false); int n, k; cin>>n>>k; int dp[n+1][n+1]={0}; 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=min(dp[i-1][j-1]+k, 1000000000); 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...