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

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

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

系統(tǒng) 2188 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ù)結(jié)構(gòu),請(qǐng)?jiān)谠擃愋椭袑?shí)現(xiàn)一個(gè)能夠得到棧最小元素的min函數(shù)。

?

輸入:

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

?

輸出:

對(duì)應(yīng)每個(gè)測試案例中的每個(gè)操作,
若棧不為空,輸出相應(yīng)的棧中最小元素。否則,輸出NULL。

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


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

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

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产精品成人国产乱一区 | 国产网站在线播放 | 久草在线视频精品 | 欧美视频福利 | 黄色免费av| 国产精品久久久久久久免费大片 | 黄色国产视频 | 久久久久久久久久爱 | 亚洲欧洲精品成人久久奇米网 | 精品极品三级久久久久 | 手机看片日韩国产 | 欧美一a一片一级一片 | 婷婷色综合久久五月亚洲 | 丁香婷婷网 | 无遮挡又黄又爽又色的动态图1000 | 欧美一区二区免费 | 日韩性freexxxx在线观看 | 一个色综合网 | 国产网站在线 | 欧美在线观看一区 | 欧美成在线视频 | 日韩 欧美 自拍 | 午夜国产电影 | 高清国产美女一级a毛片 | 国产成人手机在线好好热 | 亚洲精品在线视频观看 | 国产日韩欧美久久久 | 激情婷婷综合 | 天天艹天天干天天 | 国产精品成人av | 欧美中文字幕一区二区 | 亚洲一区二区三区四区 | 欧美激情一区二区亚洲专区 | 成人深夜视频在线观看 | 色开心| 久久久久无码国产精品一区 | 亚洲第一视频区 | 亚洲国产综合久久精品 | 中文字幕一区二区三区四区不卡 | 国外成人在线视频网站 | 丁香花成人另类小说 |