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條評論
主站蜘蛛池模板: 毛片网子| 国产在线看不卡一区二区 | 亚洲国产高清在线精品一区 | 97视频在线观看播放 | 狠狠色噜噜狠狠狠狠奇米777 | 99热精品久久只有精品黑人 | 亚洲国内自拍愉拍20页 | 理论片我不卡在线观看 | 国产精品入口牛牛影视 | 91精品中文字幕 | 五月天婷婷在线播放 | 日本高清免费不卡毛片 | 这里只有精品在线播放 | 福利姬在线视频国产观看 | 手机国产日韩高清免费看片 | 视频一区二区国产 | 亚洲一区二区免费视频 | 99热久久精品国产 | 日韩一区二区精品久久高清 | 国产精品久久久久久久久久久搜索 | 四虎私人影院 | 婷婷激情亚洲 | 久久国产成人亚洲精品影院老金 | 精品一区 二区三区免费毛片 | 免费视频不卡 | 国语精品视频在线观看不卡 | 一级成人生活片免费看 | www.久久精品 | 俺去久久 | 欧美综合图区亚欧综合图区 | 国产精品午夜久久久久久99热 | 亚洲欧美久久精品1区2区 | 久久国产亚洲 | 成 人 免费 黄 色 视频 | 一级做a爱片特黄在线观看免费看 | 一本色道久久综合一区 | 国产码欧美日韩高清综合一区 | 国产香蕉偷在线观看视频 | 14一15sexvideo日本 | 亚洲色妞| 国产在线观看成人免费视频 |