青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

C小加

厚德 博學 求真 至善 The bright moon and breeze
posts - 145, comments - 195, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

基本數據結構:棧(stack)

Posted on 2012-08-01 16:51 C小加 閱讀(7645) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構和算法

基本數據結構:棧(stack)

作者:C小加 更新時間:2012-8-1

棧(stack)是限制插入和刪除只能在一個位置上進行的線性表,該位置在表的末端,叫做棧頂。添加元素只能在尾節點后添加,刪除元素只能刪除尾節點,查看節點也只能查看尾節點。添加、刪除、查看依次為入棧(push)、出棧(pop)、棧頂節點(top)。形象的說,棧是一個先進后出(LIFO)表,先進去的節點要等到后邊進去的節點出來才能出來。


如圖1,是一個棧的形象圖,top指針指向的是棧頂節點,所以我們可以通過top訪問到2節點,但是0和1節點由于先于2進入這個表,所以是不可見的。如果把0節點當做頭節點,2節點當做尾節點,那么棧限制了訪問權限,只可以訪問尾節點。


如圖2,當添加一個節點3的時候,只能在棧頂節點,也就是尾節點后添加,這樣3節點變成了棧頂,2節點變成了不可見節點,訪問的時候只能訪問到3節點。入棧時限制了插入地址,只能在棧頂添加節點。


當我們執行出棧的命令時,圖2的棧頂元素是3節點,刪除的時候只能允許刪除棧頂的元素,這樣子3節點被刪除,top指向刪除后的棧頂2節點,如圖3所示。

棧有兩種是實現結構,一種是順序存儲結構,也就是利用數組實現,一種是鏈式存儲結構,可以用單鏈表實現。數組實現棧很簡單,用一個下標標記top來表示棧頂,top==-1時,棧空,top==0時,表示棧里只有一個元素,通過訪問top為下標的數組元素即可。出棧top自減,入棧top自加就OK了。

單鏈表實現棧要比單鏈表的實現簡單點。我們通過在表的尾端插入來實現push,通過刪除尾節點來實現pop,獲取尾節點的元素來表示top。我修改了鏈表那一章的單鏈表代碼,把頭節點當做棧頂節點,實現了一個簡單的棧模板,僅供學習所用。代碼會不定時更新。代碼下載

代碼如下:


template<class T>
class stackNode
{
    public:
    stackNode():next(NULL){}
    T data;//
    stackNode* next;//指向下一個節點的指針
};
template<class T>
class mystack
{
    private:
    unsigned int stacklength;
    stackNode<T>* node;//臨時節點
    stackNode<T>* headnode;//尾結點
    public:
        mystack();//初始化
        unsigned int length();//棧元素的個數
        void push(T x);//入棧
        bool isEmpty();//判斷棧是否為空
        void pop();//出棧
        T top();//獲得棧頂元素
        void clear();//清空棧

};
template<class T>
mystack<T>::mystack()
{
    node=NULL;
    headnode=NULL;
    stacklength=0;
}
template<class T>
inline unsigned int mystack<T>::length(){return stacklength;}
template<class T>
void  mystack<T>::push(T x)
{
    node=new stackNode<T>();
    node->data=x;
    node->next=headnode;//把node變成頭節點
    headnode=node;
    ++stacklength;
}
template<class T>
bool  mystack<T>::isEmpty()
{
    return stacklength==0;
}
template<class T>
void  mystack<T>::pop()
{
    if(isEmpty()) return;
    node=headnode;
    headnode=headnode->next;//頭節點變成它的下一個節點
    delete(node);//刪除頭節點
    --stacklength;
}
template<class T>
T  mystack<T>::top()
{
    if(!isEmpty())
    return headnode->data;
}
template<class T>
void  mystack<T>::clear()
{
    while(headnode!=NULL)
    {
        node=headnode;
        headnode=headnode->next;
        delete(node);
    }
    node=NULL;
    headnode=NULL;
    stacklength=0;
}

很清楚,除了clear函數外,所有的方法的時間復雜度都是O(1)。這種實現方式的缺點在于對newdelete的調用的開銷是昂貴的,所以采用數組的方式實現會更好一點。

棧的應用

使用棧的時候一般不用自己重新去寫,因為STL給我們實現了一個很安全的棧,可以放心去使用。也可以用數組模擬一個,很簡單。

編譯器調用函數就用了棧結構,當第一個函數還沒執行完畢,調用第二個函數的時候,編譯器就會把第一個函數壓棧,第二個函數調用完畢的時候,就會取棧頂函數,也就是第一個函數繼續執行。

平衡符號 http://acm.nyist.net/JudgeOnline/problem.php?pid=2

中綴轉后綴 http://acm.nyist.net/JudgeOnline/problem.php?pid=467

后綴試求值 http://acm.nyist.net/JudgeOnline/problem.php?pid=35

poj 3250 http://acm.pku.edu.cn/JudgeOnline/problem?id=3250

poj 1363 http://acm.pku.edu.cn/JudgeOnline/problem?id=1363

poj 1208 http://acm.pku.edu.cn/JudgeOnline/problem?id=1208

poj 1686 http://acm.pku.edu.cn/JudgeOnline/problem?id=1686

poj 3250 http://acm.pku.edu.cn/JudgeOnline/problem?id=2045

hdu 1022 http://acm.hdu.edu.cn/showproblem.php?pid=1022



 

Feedback

# re: 基本數據結構:棧(stack)  回復  更多評論   

2012-08-02 10:24 by SunRise_at
(⊙o⊙)哦..............
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品一本| 欧美日韩亚洲一区二区三区在线| 国产美女搞久久| 久久激情五月丁香伊人| 午夜久久福利| 在线看欧美视频| 亚洲国产精品精华液网站| 欧美精品国产一区| 亚洲视频一区在线| 亚洲欧美中日韩| 国产亚洲制服色| 亚洲第一页自拍| 欧美精品在线一区二区三区| 一本色道久久99精品综合| 日韩写真在线| 国产综合色在线视频区| 亚洲福利视频一区| 国产精品无码专区在线观看| 麻豆精品在线观看| 欧美激情精品久久久久久变态| 日韩亚洲精品电影| av不卡在线观看| 国产精品自拍视频| 欧美激情区在线播放| 欧美日韩精品免费观看视一区二区| 欧美亚洲自偷自偷| 免费亚洲视频| 最新中文字幕一区二区三区| 亚洲性感激情| 有码中文亚洲精品| 亚洲制服欧美中文字幕中文字幕| 91久久久亚洲精品| 亚洲综合不卡| 亚洲午夜久久久久久久久电影网| 久久精品噜噜噜成人av农村| 亚洲欧美中文日韩v在线观看| 免费在线观看一区二区| 久久夜精品va视频免费观看| 国产精品资源| 午夜精品福利一区二区三区av| 亚洲国产美女精品久久久久∴| 欧美影院成年免费版| 欧美在线资源| 国产欧美精品久久| 亚洲影院色在线观看免费| 亚洲天堂第二页| 国产精品扒开腿做爽爽爽软件 | 国产亚洲精品高潮| 亚洲综合导航| 久久久久久电影| 激情综合久久| 欧美成年人在线观看| 亚洲高清激情| 国产精品99久久久久久人 | 欧美激情一区在线| 亚洲狼人精品一区二区三区| 欧美精品三级日韩久久| 亚洲美女av在线播放| 亚洲视频在线播放| 国产精品资源在线观看| 午夜在线视频一区二区区别| 久久久久久久欧美精品| 激情久久久久| 欧美日韩综合网| 欧美一区二区三区免费观看| 久久综合五月| 亚洲精品五月天| 国产精品免费一区豆花| 另类激情亚洲| 亚洲一区二区三区影院| 亚洲成人直播| 欧美在线影院| 日韩亚洲国产精品| 狠狠爱综合网| 欧美日韩国产天堂| 久久久久国产一区二区三区| 一区二区三区视频在线看| 免费不卡在线视频| 欧美伊人影院| 亚洲一区免费网站| 亚洲国产人成综合网站| 国产精品扒开腿做爽爽爽视频 | 欧美日本韩国一区| 久久国产主播精品| 午夜精彩国产免费不卡不顿大片| 91久久午夜| 91久久国产综合久久| 欧美激情国产日韩精品一区18| 欧美一区激情| 午夜精品久久久久99热蜜桃导演| 伊人精品成人久久综合软件| 国产麻豆综合| 国产日韩精品视频一区| 国产精品影院在线观看| 欧美午夜影院| 国产精品进线69影院| 欧美怡红院视频一区二区三区| 欧美成人有码| 亚洲午夜成aⅴ人片| 夜夜嗨av色综合久久久综合网| 欧美激情亚洲自拍| 亚洲国产毛片完整版| 久久久综合激的五月天| 性娇小13――14欧美| 日韩一区二区精品视频| 日韩一级黄色av| 中国日韩欧美久久久久久久久| 亚洲欧美日韩中文播放| 快射av在线播放一区| 亚洲高清在线| 99在线精品视频在线观看| 欧美一级日韩一级| 欧美久久婷婷综合色| 红桃视频国产精品| 先锋影音国产一区| 午夜日韩在线| 亚洲精品小视频在线观看| 久久在线观看视频| 国产欧美精品va在线观看| 韩国av一区| 亚洲欧美自拍偷拍| 欧美激情精品久久久久久| 亚洲女女女同性video| 老**午夜毛片一区二区三区| 国产精品成人一区二区| 最新亚洲激情| 狂野欧美激情性xxxx欧美| 一区二区三区高清在线观看| 欧美1区2区| 精品999网站| 久久精品一区二区三区不卡牛牛| 亚洲人成人一区二区在线观看| 欧美在线91| 国产日韩欧美在线播放不卡| 在线亚洲欧美视频| 亚洲精品美女| 欧美精品免费视频| 一区二区三区不卡视频在线观看 | 亚洲欧美日韩综合国产aⅴ| 欧美日韩亚洲综合一区| 一区二区三区四区国产| 亚洲国产天堂久久综合| 欧美gay视频| 亚洲伦理自拍| 一区二区三区欧美在线观看| 欧美日韩在线影院| 性伦欧美刺激片在线观看| 亚洲字幕一区二区| 很黄很黄激情成人| 免费在线观看日韩欧美| 欧美成人一区二区三区| 在线一区二区三区四区| 亚洲一区二区三区视频| 国产一区二区三区黄视频| 蜜臀va亚洲va欧美va天堂| 免费亚洲电影在线观看| 中日韩视频在线观看| 销魂美女一区二区三区视频在线| 黄色成人片子| 日韩午夜激情| 国产农村妇女毛片精品久久麻豆| 翔田千里一区二区| 亚洲社区在线观看| 欧美日韩中文| 亚洲精品国久久99热| 欧美自拍丝袜亚洲| 久久精品99国产精品| 国产精品白丝黑袜喷水久久久| 欧美a级大片| 国内成人精品视频| 亚洲视频播放| 亚洲一区二区三区在线看 | 亚洲人体大胆视频| 国产一区二区久久精品| 日韩视频国产视频| 亚洲国产精品一区制服丝袜 | 欧美在线视频观看| 亚洲免费视频观看| 欧美成人亚洲成人| 久久久蜜桃一区二区人| 国产精品视频一区二区高潮| 日韩午夜在线| 亚洲欧美日本日韩| 国产精品久久国产三级国电话系列 | 欧美激情乱人伦| 亚洲成人影音| 亚洲女性裸体视频| 亚洲欧美视频| 国产精品日本精品| 日韩视频在线一区| 99re6热只有精品免费观看 | 久久久久久色| 久久综合伊人| 亚洲第一精品影视| 久久久91精品国产一区二区精品| 久久精品中文| 黑人一区二区三区四区五区| 久久久久久婷| 欧美激情在线| 亚洲神马久久|