/* * FileName: no_561_tokyo_kyoto * CreatedDate: 2020-04-04 10:48:11 +0900 * LastModified: 2020-04-04 20:55:32 +0900 */ #include #include int second=1; 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){ sleep(second); if(i==N){ return 0; } else{ long int box_0,box_1; if( bi==0 ){ box_0 = dp(i+1,N,D,T,K,0)+T[i]; box_1 = dp(i+1,N,D,T,K,1)+K[i]-D; printf("%d:%d{%ld,%ld}\n",i,bi,box_0,box_1); return max(box_0,box_1); } else if( bi==1 ){ box_0 = dp(i+1,N,D,T,K,0)+T[i]-D; box_1 = dp(i+1,N,D,T,K,1)+K[i]; printf("%d:%d{%ld,%ld}\n",i,bi,box_0,box_1); 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