• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            昨天看程序員面試精選100題,看到一個(gè)棧的push,pop序列問題。
            題目:輸入兩個(gè)整數(shù)序列。其中一個(gè)序列表示棧的push順序,判斷另一個(gè)序列有沒有可能是對應(yīng)的pop順序。為了簡單起見,我們假設(shè)push序列的任意兩個(gè)整數(shù)都是不相等的。比如輸入的push序列是1、2、3、4、5,那么4、5、3、2、1就有可能是一個(gè)pop系列。因?yàn)榭梢杂腥缦碌膒ush和pop序列:push 1,push 2,push 3,push 4,pop,push 5,pop,pop,pop,pop,這樣得到的pop序列就是4、5、3、2、1。但序列4、3、5、1、2就不可能是push序列1、2、3、4、5的pop序列。
            一開始還真不知道怎么下手,看了分析才知道大概方法。然后再看參考代碼,感覺還是有些復(fù)雜。自己想了個(gè)稍微簡單的方法,pop隊(duì)列還可能是push隊(duì)列的子集:
             1 #include <iostream>
             2 #include <stack>
             3 
             4 using namespace std;
             5 /*!
             6 \brief This algorithm demostrates how to judge whether or not a given seqence is
             7 possibly a popup sequence providing the pushing sequence.
             8 */
             9 
            10 bool IsPopSequence(int* ppush, int pushm, int* ppop, int popm)
            11 {
            12     int i = 0, j = 0;
            13     stack<int> help_stack;
            14     while(j < popm)
            15     {
            16         if (!help_stack.empty() && help_stack.top() == ppop[j])
            17         {
            18             help_stack.pop();
            19             j++;
            20         }
            21         else if (i < pushm)
            22         {
            23             help_stack.push(ppush[i++]);
            24         }
            25         else
            26             break;
            27     }
            28 
            29     return j >= popm;
            30 }
            31 
            32 int main(int argc, char *argv, char *env[])
            33 {
            34     //int pushseq[] = {1, 2, 3, 4, 5};
            35     //int pushseqlen = sizeof(pushseq)/sizeof(pushseq[0]);
            36     ////int popseq[] = {4, 5, 3, 2, 1};
            37     //int popseq[] = {4, 3, 5, 1, 2};
            38     //int popseqlen = sizeof(popseq)/sizeof(popseq[0]);
            39 
            40     int pushseq[] = {123456};
            41     int popseq[] = {43521};
            42     int pushseqlen = sizeof(pushseq)/sizeof(pushseq[0]);
            43     int popseqlen = sizeof(popseq)/sizeof(popseq[0]);
            44 
            45     cout<<boolalpha<<IsPopSequence(pushseq, pushseqlen, popseq, popseqlen)<<"\n";
            46 
            47     return 0;
            48 }


            posts - 9, comments - 13, trackbacks - 0, articles - 0

            Copyright © David Fang

            久久久久夜夜夜精品国产| 国产精品久久久久久久久| 天天综合久久一二三区| 国产毛片欧美毛片久久久| 久久久久久亚洲AV无码专区| 国产成人无码精品久久久久免费| 久久天天躁狠狠躁夜夜2020老熟妇| 思思久久精品在热线热| 久久九九亚洲精品| 91麻豆国产精品91久久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 欧美亚洲另类久久综合| 国产精品久久久久久久久久影院| 国产精品天天影视久久综合网| 久久亚洲精品无码观看不卡| 日韩AV无码久久一区二区| 久久久WWW成人| 久久r热这里有精品视频| 久久夜色精品国产噜噜亚洲a| 国产精品久久久久一区二区三区| 久久国产劲爆AV内射—百度| 久久久久久A亚洲欧洲AV冫| 久久青草国产精品一区| 久久婷婷五月综合国产尤物app| 欧美精品九九99久久在观看| 精品久久人人做人人爽综合| 久久99精品综合国产首页| 久久久久99精品成人片直播| 亚洲色欲久久久综合网东京热 | 狠狠色综合网站久久久久久久高清| 国产精品亚洲综合专区片高清久久久 | 伊人色综合久久天天人手人婷| 久久国产影院| 久久国产福利免费| 久久久久亚洲av成人无码电影| 国产午夜精品久久久久九九电影| 国产成人综合久久综合| 成人亚洲欧美久久久久| 久久天天躁狠狠躁夜夜2020老熟妇| 久久久久久噜噜精品免费直播| 久久久久97国产精华液好用吗|