2#include3usingnamespacestd;4classmin_stack5{6public:7voidpush(int);8voidpop();9intmin();10intsize()11{12returndata.size();13}14private:15stackdata;16stackmin_data;17};18voidmin_stack::push(intv" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

實現(xiàn)棧最小元素的min函數(shù)

系統(tǒng) 2089 0
      
         1
      
       #include<iostream>


      
         2
      
       #include<stack>


      
         3
      
      
        using
      
      
        namespace
      
      
         std;


      
      
         4
      
      
        class
      
      
         min_stack


      
      
         5
      
      
        {


      
      
         6
      
      
        public
      
      
        :


      
      
         7
      
      
        void
      
       push(
      
        int
      
      
        );


      
      
         8
      
      
        void
      
      
          pop();


      
      
         9
      
      
        int
      
      
         min();


      
      
        10
      
      
        int
      
      
         size()


      
      
        11
      
      
            {


      
      
        12
      
      
        return
      
      
         data.size();


      
      
        13
      
      
            }


      
      
        14
      
      
        private
      
      
        :


      
      
        15
      
           stack<
      
        int
      
      >
      
         data;


      
      
        16
      
           stack<
      
        int
      
      >
      
         min_data;


      
      
        17
      
      
        };


      
      
        18
      
      
        void
      
       min_stack::push(
      
        int
      
      
         value)


      
      
        19
      
      
        {


      
      
        20
      
      
            data.push(value);


      
      
        21
      
      
        if
      
       (min_data.size()==
      
        0
      
       || min_data.top() >
      
         value)


      
      
        22
      
      
            { 


      
      
        23
      
      
                min_data.push(value);


      
      
        24
      
      
            }


      
      
        25
      
      
        else
      
      
        26
      
      
            {


      
      
        27
      
      
                min_data.push(min_data.top());


      
      
        28
      
      
            }


      
      
        29
      
      
        }


      
      
        30
      
      
        void
      
      
         min_stack::pop()


      
      
        31
      
      
        {


      
      
        32
      
      
        if
      
       (data.size()>
      
        0
      
      
        )


      
      
        33
      
      
            {


      
      
        34
      
      
                min_data.pop();


      
      
        35
      
      
                data.pop();


      
      
        36
      
      
            }


      
      
        37
      
      
        }


      
      
        38
      
      
        int
      
      
         min_stack::min()


      
      
        39
      
      
        {


      
      
        40
      
      
        return
      
      
         min_data.top();


      
      
        41
      
      
        }


      
      
        42
      
      
        43
      
      
        int
      
       main(
      
        int
      
       argc, 
      
        char
      
       **
      
        argv)


      
      
        44
      
      
        {


      
      
        45
      
      
        int
      
      
         n,m;


      
      
        46
      
      
        char
      
      
         ci;


      
      
        47
      
      
        while
      
      (cin>>
      
        n)


      
      
        48
      
      
            {


      
      
        49
      
      
                min_stack mystack;


      
      
        50
      
      
        for
      
       (
      
        int
      
       i=
      
        0
      
      ; i<n; i++
      
        )


      
      
        51
      
      
                {


      
      
        52
      
                   cin>>
      
        ci;


      
      
        53
      
      
        switch
      
      
         (ci)


      
      
        54
      
      
                    {


      
      
        55
      
      
        case
      
      
        '
      
      
        s
      
      
        '
      
      
        :


      
      
        56
      
                       cin>>
      
        m;


      
      
        57
      
      
                        mystack.push(m);


      
      
        58
      
                       cout<<mystack.min()<<
      
        endl;


      
      
        59
      
      
        break
      
      
        ;


      
      
        60
      
      
        case
      
      
        '
      
      
        o
      
      
        '
      
      
        :


      
      
        61
      
      
                        mystack.pop();


      
      
        62
      
      
        if
      
       (mystack.size()==
      
        0
      
      
        )


      
      
        63
      
      
                        {


      
      
        64
      
                           cout<<
      
        "
      
      
        NULL
      
      
        "
      
      <<
      
        endl;


      
      
        65
      
      
                        }


      
      
        66
      
      
        else
      
      
        67
      
      
                        {


      
      
        68
      
                           cout<<mystack.min()<<
      
        endl;


      
      
        69
      
      
                        }


      
      
        70
      
      
        break
      
      
        ;


      
      
        71
      
      
                    }


      
      
        72
      
      
                }   


      
      
        73
      
      
            }


      
      
        74
      
      
        return
      
      
        1
      
      
        ;


      
      
        75
      
      
        }


      
      
        76
      
      
        /*
      
      
        *************************************************************


      
      
        77
      
      
            Problem: 1522


      
      
        78
      
      
            User: xuebintian


      
      
        79
      
      
            Language: C++


      
      
        80
      
      
            Result: Accepted


      
      
        81
      
      
            Time:140 ms


      
      
        82
      
      
            Memory:1524 kb


      
      
        83
      
      
        ***************************************************************
      
      
        */
      
    
題目描述:

定義棧的數(shù)據(jù)結構,請在該類型中實現(xiàn)一個能夠得到棧最小元素的min函數(shù)。

?

輸入:

輸入可能包含多個測試樣例,輸入以EOF結束。
對于每個測試案例,輸入的第一行為一個整數(shù)n(1<=n<=1000000), n代表將要輸入的操作的步驟數(shù)。
接下來有n行,每行開始有一個字母Ci。
Ci=’s’時,接下有一個數(shù)字k,代表將k壓入棧。
Ci=’o’時,彈出棧頂元素。

?

輸出:

對應每個測試案例中的每個操作,
若棧不為空,輸出相應的棧中最小元素。否則,輸出NULL。

實現(xiàn)棧最小元素的min函數(shù)


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】元

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美日韩视频在线 | 美妇乱人伦性 | 久久er国产精品免费观看1 | 日本精品99| 中文字幕免费视频精品一 | 模特精品视频一区 | 色女人综合 | 久久日本精品99久久久 | 毛片大全高清免费 | 国产成人毛片视频不卡在线 | 91青青青| 久精品视频 | 欧美成人免费一区在线播放 | 五月中文字幕 | 日本高清中文字幕 | 国产精品亚洲一区在线播放 | 1024国产欧美日韩精品 | 在线观看视频一区二区 | 亚洲精品国产精品一区二区 | 青青青国产 | 国产午夜亚洲精品第一区 | 日日干天天爽 | 精品久久久久亚洲 | 成人深夜网站 | 日韩在线视频一区 | 全部毛片免费看 | 国产精品99一区二区三区 | 欧美成人天天综合在线视色 | 欧美aⅴ片| 亚洲欧美在线视频免费 | 精品乱码一区二区三区四区 | 亚洲色婷婷综合开心网 | 国产一区二区免费播放 | 99伊人 | 狠狠2019| 日本一区二区三区在线 观看网站 | 欧美专区在线观看 | 欧美一区三区 | 国内偷自视频区视频综合 | 亚洲国产精品a在线 | 亚洲欧美日韩伦中文 |