欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

手把手帶你了解C++最小棧

 更新時(shí)間:2021年08月19日 10:18:46   作者:久病成良醫(yī)  
這篇文章主要介紹了C++的最小棧,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

設(shè)計(jì)一個(gè)支持 push ,pop ,top 操作,并能在常數(shù)時(shí)間內(nèi)檢索到最小元素的棧。

push(x) —— 將元素 x 推入棧中。

pop() —— 刪除棧頂?shù)脑亍?br />

top() —— 獲取棧頂元素。

getMin() —— 檢索棧中的最小元素。

示例:

輸入:

[“MinStack”,“push”,“push”,“push”,“getMin”,“pop”,“top”,“getMin”]

[[],[-2],[0],[-3],[],[],[],[]]

輸出:

[null,null,null,null,-3,null,0,-2]

解釋:

MinStack minStack = new MinStack();

minStack.push(-2);

minStack.push(0);

minStack.push(-3);

minStack.getMin(); --> 返回 -3.

minStack.pop();

minStack.top(); --> 返回 0.

minStack.getMin(); --> 返回 -2.

思路

C++支持的棧(原生棧),可以實(shí)現(xiàn) push、pop、top(peek), 但是要獲取最小元素, 一種方法是通過暴力搜索,從頭到尾遍歷整個(gè),那么時(shí)間復(fù)雜度是 O(n),不是在常數(shù)級(jí)獲取最小值, 不符合題目的要求。

我們可以設(shè)置兩個(gè)棧,一個(gè)數(shù)據(jù)棧 datastack,用于存放需要存放的數(shù)據(jù),一個(gè)記錄最小值的棧 sortedstack。

在這里插入圖片描述

每次 push 操作之后, 保存當(dāng)前 push 元素之后數(shù)據(jù)棧中的最小值, 因?yàn)閺牡谝淮?push 到之后的每次 push 操作,我們知道每次 push 的值,也很容易知道當(dāng)前的棧中的最小值。

在這里插入圖片描述

```cpp
class MinStack {
public:
    /** initialize your data structure here. */
    //創(chuàng)建兩個(gè)棧
    stack<int> datastack; //數(shù)據(jù)棧
    stack<int> sortedstack; //有序棧,棧底最大,棧頂最小,有<=棧頂?shù)脑夭舙ush
    MinStack() {
    }
    void push(int val) {
        datastack.push(val); //將值push到數(shù)據(jù)棧
        //有序棧
        //當(dāng)有序棧為空 或 值小于等于有序棧的棧頂 就push
        if(sortedstack.empty()||val<=sortedstack.top()) //sortedstack==sortedstack.empty() 錯(cuò)誤
            sortedstack.push(val);
    }
    void pop() {
        if(datastack.top()==sortedstack.top())  //數(shù)據(jù)棧的棧頂 和 有序棧的棧頂 相同, 有序棧出棧
            sortedstack.pop();
        datastack.pop();  //數(shù)據(jù)棧一直在出棧
    }         
    int top() {
        return datastack.top();
    }
    int getMin() {
        return sortedstack.top();
    }
};
/**
 * Your MinStack object will be instantiated and called as such:
 * MinStack* obj = new MinStack();
 * obj->push(val);
 * obj->pop();
 * int param_3 = obj->top();
 * int param_4 = obj->getMin();
 */

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • C語言中的sscanf()函數(shù)使用詳解

    C語言中的sscanf()函數(shù)使用詳解

    這篇文章主要介紹了C語言中的sscanf()函數(shù)使用詳解,文中附加了一道相關(guān)的ACM題目進(jìn)行補(bǔ)充鞏固,需要的朋友可以參考下
    2015-08-08
  • C及C++?基礎(chǔ)循環(huán)示例詳解

    C及C++?基礎(chǔ)循環(huán)示例詳解

    這篇文章主要介紹了C及C++?中的循環(huán)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • C++ 詳解數(shù)據(jù)結(jié)構(gòu)中的搜索二叉樹

    C++ 詳解數(shù)據(jù)結(jié)構(gòu)中的搜索二叉樹

    搜索二叉樹是一種具有良好排序和查找性能的二叉樹數(shù)據(jù)結(jié)構(gòu),包括多種操作,本篇只介紹插入,排序(遍歷),和刪除操作,重點(diǎn)是刪除操作比較復(fù)雜
    2022-04-04
  • C++實(shí)現(xiàn)LeetCode(76.最小窗口子串)

    C++實(shí)現(xiàn)LeetCode(76.最小窗口子串)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(76.最小窗口子串),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語言實(shí)現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計(jì)

    C語言實(shí)現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Qt無邊框窗口拖拽和陰影的實(shí)現(xiàn)

    Qt無邊框窗口拖拽和陰影的實(shí)現(xiàn)

    自定義窗口控件的無邊框,窗口事件由于沒有系統(tǒng)自帶邊框,無法實(shí)現(xiàn)拖拽拉伸等事件的處理,本文主要介紹了Qt無邊框窗口拖拽和陰影的實(shí)現(xiàn),感興趣的可以了解一下
    2024-01-01
  • Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows)

    Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows)

    Clion2020增加了很多新特性,修復(fù)了大量bug,大大提高了開發(fā)效率。這篇文章主要介紹了Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows),需要的朋友可以參考下
    2020-11-11
  • C++中const的用法詳細(xì)總結(jié)

    C++中const的用法詳細(xì)總結(jié)

    以下是對(duì)C++中const的用法進(jìn)行了詳細(xì)的總結(jié)分析,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2013-09-09
  • Qt sender()函數(shù)的具體使用

    Qt sender()函數(shù)的具體使用

    在處理信號(hào)時(shí),Qt提供了一個(gè)特殊的函數(shù)sender(),可以返回發(fā)送信號(hào)的對(duì)象指針,以實(shí)現(xiàn)更靈活的代碼邏輯,本文就來介紹一下Qt sender()函數(shù)的具體使用,感興趣的可以了解一下
    2024-01-01
  • C語言特殊符號(hào)的補(bǔ)充理解

    C語言特殊符號(hào)的補(bǔ)充理解

    這篇文章主要為大家介紹了C語言特殊符號(hào)的使用補(bǔ)充理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-02-02

最新評(píng)論