Advertisement
akashtadwai

LC

Jul 26th, 2021
1,049
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.02 KB | None | 0 0
  1. #define ll long long
  2. class Solution {
  3. public:
  4.     int maxSumMinProduct(vector<int>& a) {
  5.         const int mod = 1e9+7;
  6.         int n = a.size();
  7.         vector<ll>l(n),r(n);
  8.         vector<ll>pref(n);
  9.         ll cur=0;
  10.         for(int i=0;i<n;i++){
  11.             cur+=a[i];
  12.             pref[i]=cur;
  13.         }
  14.        
  15.         stack<int>s;
  16.         for(int i=0;i<n;i++){
  17.             while(!s.empty() and a[s.top()]>=a[i]) s.pop();
  18.             if(s.empty()) l[i]=-1;
  19.             else l[i]=s.top();
  20.             s.push(i);
  21.         }
  22.         while(!s.empty()) s.pop();
  23.          for(int i=n-1;i>=0;i--){
  24.             while(!s.empty() and a[s.top()]>=a[i]) s.pop();
  25.             if(s.empty()) r[i]=n;
  26.             else r[i]=s.top();
  27.              s.push(i);
  28.         }
  29.        ll ans=0;
  30.         for(int i=0;i<n;++i) {
  31.             int l_range = l[i],r_range = r[i];
  32. cur =  (( (long long)(pref[r_range-1]-(l_range==-1?0:pref[l_range]))*a[i])%mod);
  33.         ans=max(ans,cur);
  34.        
  35.     }
  36.         return ans;
  37.  
  38.        
  39.     }
  40. };
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement