Advertisement
SuitNdtie

ore2

May 30th, 2019
114
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.07 KB | None | 0 0
  1. #include<stdio.h>
  2. #include<queue>
  3. #include<deque>
  4. using namespace std;
  5. typedef long long int ll;
  6. ll const inf = 1e18;
  7. int const N = 1000010;
  8. int n;
  9. ll k;
  10.  
  11. inline ll max(ll a,ll b){
  12.     return (a > b ? a : b);
  13. }
  14.  
  15.  
  16.  
  17. ll qs[N];
  18. ll arr[N];
  19. ll dp[N];
  20.  
  21. int main()
  22. {
  23.     scanf("%d %lld",&n,&k);
  24.     for(int i = 1 ; i <= n ; i++){
  25.         scanf("%lld",&arr[i]);
  26.         qs[i] = qs[i-1] + arr[i];
  27.     }
  28.     dp[0] = 0;
  29.    
  30.     priority_queue<pair<ll,int> > pq;
  31.     pq.push({0,0});
  32.    
  33.     deque<pair<ll,int> > dq;
  34.     dq.push_back({0,0});
  35.    
  36.     //bottom up
  37.     for(int i = 1 ; i <= n ; i ++){
  38.     //  while(!pq.empty() && pq.top().first - dp[pq.top().second - 1] + qs[i] > k)pq.pop();
  39.        
  40.         while(!dq.empty() && dq.front().first - dp[dq.front().second - 1] + qs[i] > k)dq.pop_front();
  41.        
  42.     //  dp[i] = max(dp[i-1] ,pq.empty() ? 0 : pq.top().first + qs[i]);
  43.        
  44.         dp[i] = max(dp[i-1] , dq.empty() ? 0 : dq.front().first + qs[i]);
  45.        
  46.     //  pq.push({dp[i-1]-qs[i],i});
  47.        
  48.         while(!dq.empty() && dq.back().first < dp[i-1]-qs[i])dq.pop_back();
  49.         dq.push_back({dp[i-1]-qs[i],i});
  50.     }
  51.     printf("%lld",dp[n]);
  52.     return 0;
  53. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement