/* * FileName: no_561_tokyo_kyoto * CreatedDate: 2020-04-04 10:48:11 +0900 * LastModified: 2020-04-04 19:11:10 +0900 */ #include long int max(long int s, long int t){ if(s>t){ return s; } else{ return t; } } long int dp( int i, int N, long int D, long int T[], long int K[], int bi){ if(i==N){ return 0; } else if( bi==0 ){ long int box_0 = dp(i+1,N,D,T,K,0)+T[i]; long int box_1 = dp(i+1,N,D,T,K,1)+K[i]-D; return max(box_0,box_1); } else{ long int box_0 = dp(i+1,N,D,T,K,0)+T[i]-D; long int box_1 = dp(i+1,N,D,T,K,1)+K[i]; return max(box_0,box_1); } } int main(void){ int N; long int D; scanf("%d %ld",&N,&D); long int T[N],K[N]; for(int i=0;i