201312-3(O(n)算法)

#include <bits/stdc++.h>
using namespace std;
//不是递增的话就删掉,然后重新计算一次 
int getMaxArea(vector<int> &vec)
{
    stack<int> s;
    int max_area = 0;
    int i=0;
    int tp,area_with_top;
    while(i < vec.size()){
        if(s.empty() || vec[s.top()] <= vec[i])//栈是空的时候,或者栈顶元素小于当前vector所出的元素 
        s.push(i++);
        else
        {
            tp = s.top();
            s.pop();
            area_with_top = vec[tp]*(s.empty()? i:i-s.top()-1);
            max_area = max(max_area,area_with_top);
        }
    }
    while(!s.empty())
    {
        tp = s.top();
        s.pop();
        area_with_top = vec[tp] * (s.empty() ? i : i-s.top()-1);
        max_area = max(max_area, area_with_top);
    }
    return max_area;
}
int main(){
    int N;
    vector<int> vec;
    cin>>N;
    for(int i=0;i<N;++i)
    {
        int val;
        cin>>val;
        vec.emplace_back(val);
    }
    cout << getMaxArea(vec);
    return 0;
} 

 

posted @ 2020-09-23 22:45  zmachine  阅读(135)  评论(0编辑  收藏  举报