亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++怎么獲取最小棧

發布時間:2021-07-29 20:37:08 來源:億速云 閱讀:116 作者:chen 欄目:開發技術

本篇內容介紹了“C++怎么獲取最小棧”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

最小棧

Design a stack that supports push, pop, top, and retrieving the minimum element in constant time.

  • push(x) -- Push element x onto stack.

  • pop() -- Removes the element on top of the stack.

  • top() -- Get the top element.

  • getMin() -- Retrieve the minimum element in the stack.

Example:

MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> Returns -3.
minStack.pop();
minStack.top();      --> Returns 0.
minStack.getMin();   --> Returns -2.

這道最小棧跟原來的棧相比就是多了一個功能,可以返回該棧的最小值。使用兩個棧來實現,一個棧來按順序存儲 push 進來的數據,另一個用來存出現過的最小值。代碼如下:

C++ 解法一: 

class MinStack {
public:
    MinStack() {}    
    void push(int x) {
        s1.push(x);
        if (s2.empty() || x <= s2.top()) s2.push(x);
    }    
    void pop() {
        if (s1.top() == s2.top()) s2.pop();
        s1.pop();
    }  
    int top() {
        return s1.top();
    }    
    int getMin() {
        return s2.top();
    }
    
private:
    stack<int> s1, s2;
};

Java 解法一:

public class MinStack {
    private Stack<Integer> s1 = new Stack<>();
    private Stack<Integer> s2 = new Stack<>();
    
    public MinStack() {}  
    public void push(int x) {
        s1.push(x);
        if (s2.isEmpty() || s2.peek() >= x) s2.push(x);
    }
    public void pop() {
        int x = s1.pop();
        if (s2.peek() == x) s2.pop();
    }   
    public int top() {
        return s1.peek();
    }  
    public int getMin() {
        return s2.peek();
    }
}

需要注意的是上面的 Java 解法中的 pop() 中,為什么不能用注釋掉那兩行的寫法,博主之前也不太明白為啥不能對兩個 stack 同時調用 peek() 函數來比較,如果是這種寫法,那么不管 s1 和 s2 對棧頂元素是否相等,永遠返回 false。這是為什么呢,這就要看 Java 對于peek的定義了,對于 peek() 函數的返回值并不是 int 類型,而是一個 Object 類型,這是一個基本的對象類型,如果直接用雙等號 == 來比較的話,肯定不會返回 true,因為是兩個不同的對象,所以一定要先將一個轉為 int 型,然后再和另一個進行比較,這樣才能得到想要的答案,這也是 Java 和 C++ 的一個重要的不同點吧。

那么下面再來看另一種解法,這種解法只用到了一個棧,還需要一個整型變量 min_val 來記錄當前最小值,初始化為整型最大值,然后如果需要進棧的數字小于等于當前最小值 min_val,則將 min_val 壓入棧,并且將 min_val 更新為當前數字。在出棧操作時,先將棧頂元素移出棧,再判斷該元素是否和 min_val 相等,相等的話將 min_val 更新為新棧頂元素,再將新棧頂元素移出棧即可,參見代碼如下:

C++ 解法二: 

class MinStack {
public:
    MinStack() {
        min_val = INT_MAX;
    }  
    void push(int x) {
        if (x <= min_val) {
            st.push(min_val);
            min_val = x;
        }
        st.push(x);
    }   
    void pop() {
        int t = st.top(); st.pop();
        if (t == min_val) {
            min_val = st.top(); st.pop();
        }
    }  
    int top() {
        return st.top();
    }    
    int getMin() {
        return min_val;
    }
private:
    int min_val;
    stack<int> st;
};

Java 解法二:

public class MinStack {
    private int min_val = Integer.MAX_VALUE;
    private Stack<Integer> s = new Stack<>();
    
    public MinStack() {}  
    public void push(int x) {
        if (x <= min_val) {
            s.push(min_val);
            min_val = x;
        }
        s.push(x);
    }    
    public void pop() {
        if (s.pop() == min_val) min_val = s.pop();
    }   
    public int top() {
        return s.peek();
    }    
    public int getMin() {
        return min_val;
    }
}

“C++怎么獲取最小棧”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

都昌县| 大同市| 平遥县| 井冈山市| 大埔区| 华亭县| 朝阳县| 名山县| 凤台县| 朔州市| 韩城市| 吉水县| 承德市| 神木县| 成武县| 囊谦县| 霍林郭勒市| 柳林县| 济阳县| 台江县| 玉龙| 都昌县| 都安| 金秀| 班戈县| 万山特区| 浦江县| 栾川县| 芮城县| 英超| 东兴市| 太湖县| 穆棱市| 临沂市| 五大连池市| 陆河县| 呼图壁县| 邮箱| 雅江县| 利津县| 山阳县|