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

C小加

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

基本數(shù)據(jù)結(jié)構(gòu):棧(stack)

作者:C小加 更新時(shí)間:2012-8-1

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


如圖1,是一個(gè)棧的形象圖,top指針指向的是棧頂節(jié)點(diǎn),所以我們可以通過(guò)top訪問(wèn)到2節(jié)點(diǎn),但是0和1節(jié)點(diǎn)由于先于2進(jìn)入這個(gè)表,所以是不可見的。如果把0節(jié)點(diǎn)當(dāng)做頭節(jié)點(diǎn),2節(jié)點(diǎn)當(dāng)做尾節(jié)點(diǎn),那么棧限制了訪問(wèn)權(quán)限,只可以訪問(wèn)尾節(jié)點(diǎn)。


如圖2,當(dāng)添加一個(gè)節(jié)點(diǎn)3的時(shí)候,只能在棧頂節(jié)點(diǎn),也就是尾節(jié)點(diǎn)后添加,這樣3節(jié)點(diǎn)變成了棧頂,2節(jié)點(diǎn)變成了不可見節(jié)點(diǎn),訪問(wèn)的時(shí)候只能訪問(wèn)到3節(jié)點(diǎn)。入棧時(shí)限制了插入地址,只能在棧頂添加節(jié)點(diǎn)。


當(dāng)我們執(zhí)行出棧的命令時(shí),圖2的棧頂元素是3節(jié)點(diǎn),刪除的時(shí)候只能允許刪除棧頂?shù)脑兀@樣子3節(jié)點(diǎn)被刪除,top指向刪除后的棧頂2節(jié)點(diǎn),如圖3所示。

棧有兩種是實(shí)現(xiàn)結(jié)構(gòu),一種是順序存儲(chǔ)結(jié)構(gòu),也就是利用數(shù)組實(shí)現(xiàn),一種是鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu),可以用單鏈表實(shí)現(xiàn)。數(shù)組實(shí)現(xiàn)棧很簡(jiǎn)單,用一個(gè)下標(biāo)標(biāo)記top來(lái)表示棧頂,top==-1時(shí),棧空,top==0時(shí),表示棧里只有一個(gè)元素,通過(guò)訪問(wèn)top為下標(biāo)的數(shù)組元素即可。出棧top自減,入棧top自加就OK了。

單鏈表實(shí)現(xiàn)棧要比單鏈表的實(shí)現(xiàn)簡(jiǎn)單點(diǎn)。我們通過(guò)在表的尾端插入來(lái)實(shí)現(xiàn)push,通過(guò)刪除尾節(jié)點(diǎn)來(lái)實(shí)現(xiàn)pop,獲取尾節(jié)點(diǎn)的元素來(lái)表示top。我修改了鏈表那一章的單鏈表代碼,把頭節(jié)點(diǎn)當(dāng)做棧頂節(jié)點(diǎn),實(shí)現(xiàn)了一個(gè)簡(jiǎn)單的棧模板,僅供學(xué)習(xí)所用。代碼會(huì)不定時(shí)更新。代碼下載

代碼如下:


template<class T>
class stackNode
{
    public:
    stackNode():next(NULL){}
    T data;//
    stackNode* next;//指向下一個(gè)節(jié)點(diǎn)的指針
};
template<class T>
class mystack
{
    private:
    unsigned int stacklength;
    stackNode<T>* node;//臨時(shí)節(jié)點(diǎn)
    stackNode<T>* headnode;//尾結(jié)點(diǎn)
    public:
        mystack();//初始化
        unsigned int length();//棧元素的個(gè)數(shù)
        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變成頭節(jié)點(diǎn)
    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;//頭節(jié)點(diǎn)變成它的下一個(gè)節(jié)點(diǎn)
    delete(node);//刪除頭節(jié)點(diǎn)
    --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函數(shù)外,所有的方法的時(shí)間復(fù)雜度都是O(1)。這種實(shí)現(xiàn)方式的缺點(diǎn)在于對(duì)newdelete的調(diào)用的開銷是昂貴的,所以采用數(shù)組的方式實(shí)現(xiàn)會(huì)更好一點(diǎn)。

棧的應(yīng)用

使用棧的時(shí)候一般不用自己重新去寫,因?yàn)?span lang="EN-US">STL給我們實(shí)現(xiàn)了一個(gè)很安全的棧,可以放心去使用。也可以用數(shù)組模擬一個(gè),很簡(jiǎn)單。

編譯器調(diào)用函數(shù)就用了棧結(jié)構(gòu),當(dāng)?shù)谝粋€(gè)函數(shù)還沒(méi)執(zhí)行完畢,調(diào)用第二個(gè)函數(shù)的時(shí)候,編譯器就會(huì)把第一個(gè)函數(shù)壓棧,第二個(gè)函數(shù)調(diào)用完畢的時(shí)候,就會(huì)取棧頂函數(shù),也就是第一個(gè)函數(shù)繼續(xù)執(zhí)行。

平衡符號(hào) http://acm.nyist.net/JudgeOnline/problem.php?pid=2

中綴轉(zhuǎn)后綴 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: 基本數(shù)據(jù)結(jié)構(gòu):棧(stack)  回復(fù)  更多評(píng)論   

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>
            国产精品麻豆成人av电影艾秋| 欧美吻胸吃奶大尺度电影| 午夜一级在线看亚洲| 欧美在线电影| 国产精品久久久对白| 亚洲国产婷婷香蕉久久久久久99| 亚洲婷婷综合色高清在线| 欧美电影免费观看高清完整版| 亚洲一区二区在线| 一本色道**综合亚洲精品蜜桃冫| 久久久亚洲高清| 国产亚洲aⅴaaaaaa毛片| 宅男精品导航| 亚洲日本成人女熟在线观看| 久久国产精品久久久久久久久久| 国产精品乱码久久久久久| 中日韩男男gay无套| 亚洲精选国产| 欧美人与禽猛交乱配| 亚洲人成人77777线观看| 欧美激情一级片一区二区| 免费成人毛片| 日韩一级精品视频在线观看| 亚洲电影一级黄| 亚洲小说春色综合另类电影| 国产精品成人一区二区三区吃奶 | 国产精品黄色| 一本久久a久久精品亚洲| 美女性感视频久久久| 欧美专区亚洲专区| 一区二区三区视频在线观看| 国产精品成人一区二区三区吃奶| 在线视频一区观看| 亚洲视频1区2区| 国产精品夜色7777狼人| 小嫩嫩精品导航| 亚洲淫性视频| 国产专区一区| 欧美成人一二三| 欧美日韩日韩| 欧美一区二区免费观在线| 欧美一区二区在线观看| **网站欧美大片在线观看| 欧美aⅴ一区二区三区视频| 欧美电影在线观看完整版| 一区二区国产日产| 国产精品99久久久久久久女警| 国产精品三级视频| 欧美88av| 欧美午夜精品久久久久免费视 | 一二三区精品| 亚洲婷婷国产精品电影人久久| 国产日韩精品视频一区| 欧美国产精品专区| 国产精品毛片一区二区三区| 巨乳诱惑日韩免费av| 久久亚洲欧美国产精品乐播| 欧美国产另类| 久久国产综合精品| 欧美xart系列高清| 亚洲欧美偷拍卡通变态| 老司机免费视频一区二区| 一区二区三区色| 久久精品视频网| 在线视频日韩| 欧美影院成人| 亚洲视频导航| 久久精品国产精品亚洲| 亚洲欧美日韩精品久久| 永久免费毛片在线播放不卡| 一区二区三区高清| 91久久精品日日躁夜夜躁欧美| 亚洲性感美女99在线| 亚洲人在线视频| 亚洲欧美久久久| 99成人在线| 老色批av在线精品| 亚洲欧美制服另类日韩| 欧美激情网友自拍| 欧美成人首页| 狠狠色狠狠色综合日日小说| 亚洲一区二区三区四区五区午夜 | 欧美片网站免费| 免费一级欧美片在线播放| 国产精品欧美一区二区三区奶水| 亚洲国产精品成人综合| 久久成人一区| 亚洲欧美日韩在线一区| 欧美精品一二三| 亚洲盗摄视频| 亚洲欧美激情精品一区二区| 一区二区日本视频| 欧美精品久久久久久久| 欧美11—12娇小xxxx| 黄色成人在线网站| 欧美一区二区三区精品 | 亚洲国产精品一区| 激情综合自拍| 久久精品水蜜桃av综合天堂| 久久久久se| 黄色亚洲精品| 久久久久久亚洲综合影院红桃| 欧美一区视频| 国产毛片一区| 亚洲免费视频中文字幕| 欧美一区观看| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲一区二区在| 午夜国产不卡在线观看视频| 亚洲免费在线观看| 午夜精品久久久久久久白皮肤 | 亚洲第一福利视频| 美乳少妇欧美精品| 亚洲人成在线播放| 日韩亚洲欧美精品| 欧美日韩在线视频首页| 一区二区三区欧美在线| 亚洲女同在线| 国产欧美日韩亚洲一区二区三区| 校园激情久久| 欧美xart系列高清| 亚洲美女黄网| 国产精品久久久久久模特| 香蕉久久精品日日躁夜夜躁| 久久国内精品视频| 亚洲国产91精品在线观看| 欧美激情视频在线播放| 亚洲一本视频| 猫咪成人在线观看| 国产精品亚洲第一区在线暖暖韩国| 亚洲欧洲精品成人久久奇米网| 欧美激情中文不卡| 亚洲一区二区伦理| 久久手机免费观看| aa成人免费视频| 国产一区二区三区高清在线观看| 久久在线视频在线| 一区二区三区产品免费精品久久75| 欧美在线国产精品| 亚洲精品一区二区三区四区高清| 欧美午夜电影一区| 久久久久久色| 在线一区二区三区做爰视频网站| 久久精品观看| 日韩一级不卡| 国产原创一区二区| 欧美国产欧美综合 | 国产日韩一区欧美| 欧美大片第1页| 午夜视频在线观看一区| 亚洲国产日韩欧美在线99| 性欧美18~19sex高清播放| 亚洲第一在线综合网站| 国产精品免费视频xxxx| 免费中文日韩| 午夜在线电影亚洲一区| 亚洲精品美女91| 久久久久久网站| 亚洲伊人色欲综合网| 亚洲精品日韩一| 国产主播精品| 国产精品日韩专区| 欧美日韩免费观看一区二区三区| 午夜欧美视频| 亚洲网站视频| 亚洲激情校园春色| 久久亚洲一区二区| 亚洲欧美三级伦理| 一级成人国产| 日韩午夜电影在线观看| 极品少妇一区二区三区精品视频| 国产精品对白刺激久久久| 欧美激情亚洲激情| 裸体一区二区| 久久不射电影网| 亚洲一区国产一区| 日韩午夜在线| 亚洲三级国产| 欧美激情aaaa| 免费不卡中文字幕视频| 国产一区成人| 国产亚洲欧美日韩精品| 黑人极品videos精品欧美裸| 国产精品日韩专区| 国产精品人人做人人爽| 欧美日韩综合久久| 欧美三区在线观看| 欧美日韩在线第一页| 欧美日韩国产页| 欧美日韩一区二区三区免费看 | 午夜宅男欧美| 亚洲欧美日韩精品久久亚洲区| 亚洲制服av| 欧美一区观看| 久久女同互慰一区二区三区| 久久精品国产亚洲精品| 农村妇女精品| 日韩视频在线一区二区三区| 亚洲性夜色噜噜噜7777| 久久精品理论片|