• <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>
            隨筆 - 181  文章 - 15  trackbacks - 0
            <2008年12月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            My Tech blog

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

                    數(shù)據(jù)結(jié)構(gòu)上面在講到棧的時(shí)候,順便提了一下遞歸。實(shí)際上遞歸就是用棧來實(shí)現(xiàn)的。在很多算法書上,對于一些用遞歸方式寫成的算法,相應(yīng)的也給出了棧的算法。這里我要把fibonacci數(shù)列分別用遞歸和棧的方式寫出來,由于我以前的算法教材丟失了,而數(shù)據(jù)結(jié)構(gòu)中也沒有給出相應(yīng)的偽碼,所以只有自己從頭寫起了。
                    首先是fibonacci的遞歸寫法(不是很標(biāo)準(zhǔn),但是很親切):
            int fib(int value)
            {
                
            if(0==value)
                    
            return 0;
                
            else
                    
            if(1==value)
                        
            return 1;
                    
            else
                    {
                        
            return fib(value-1)+fib(value-2);
                    }
            }
                    接下來要把這個(gè)算法轉(zhuǎn)換為使用棧的寫法。
                    首先進(jìn)行一下分析。遞歸是逆向求結(jié)果的,對于不能求出結(jié)果的函數(shù),先將運(yùn)行場景壓棧,然后遞歸調(diào)用自己,如果仍然不能出結(jié)果,就再將運(yùn)行場景壓棧,一直到函數(shù)可以返回結(jié)果為止。此時(shí)依次將運(yùn)行場景彈棧,完成運(yùn)行場景,取得返回值,再彈棧......印象中的遞歸調(diào)用過程就是如此。如果我們要自己寫遞歸求fibonacci數(shù)列,就要自己手動(dòng)用程序來模擬這個(gè)過程。我首先準(zhǔn)備一個(gè)棧來存放結(jié)果序列。在這個(gè)結(jié)果序列里面,保證第一個(gè)結(jié)果和第二個(gè)結(jié)果總是可以直接求得的數(shù)值。因?yàn)橹恍枰猲-1和n-2便能求出fib(n),所以我們在算法中要把多余的n-3彈出,這樣棧內(nèi)的元素個(gè)數(shù)在每一次調(diào)用的過程中逐漸減少,一直到里面只剩下一個(gè)元素,在這個(gè)時(shí)候,剛才彈出的兩個(gè)元素之和就是我們要求的fibonacci(n)。
                    下面是算法:
            int fibByStack(int value)
            {
                
            int currentValue;
                currentValue
            =value;
                
            while(currentValue>=0)
                {
                    fibStack.push(currentValue);
                    currentValue
            --;
                }
                fibStack.pop();
                fibStack.pop();
                //1和0是n=1和n=0時(shí)的值,為了強(qiáng)調(diào)壓入的是“結(jié)果”,我將頭兩個(gè)元素彈出再壓入這兩個(gè)值
                fibStack.push(
            1);
                fibStack.push(
            0);
                
            while(true)
                {
                    
            int topValue1,topValue2
                    topValue1
            =fibStack.top();
                    fibStack.pop();
                    topValue2
            =fibStack.top();        
                    fibStack.pop();
                    
            if(1==fibStack.size())
                        
            return topValue1+topValue2;
                    fibStack.pop();        
                    fibStack.push(topValue1
            +topValue2);
                    fibStack.push(topValue2);
                }
            }
            posted on 2007-06-17 17:19 littlegai 閱讀(803) 評論(0)  編輯 收藏 引用 所屬分類: 我的讀書筆記
            天天影视色香欲综合久久| 亚洲精品第一综合99久久| 久久99国产精品久久久| 香蕉久久一区二区不卡无毒影院| 精品久久一区二区| 午夜视频久久久久一区 | 国产免费久久精品99久久| 久久se精品一区二区| 欧美日韩精品久久久久 | 午夜精品久久久久久| 国产精品99久久99久久久| 九九久久精品国产| 色偷偷久久一区二区三区| 一本综合久久国产二区| 97精品伊人久久久大香线蕉| 亚洲αv久久久噜噜噜噜噜| 国内精品久久久久久久久电影网| 伊人久久大香线蕉av一区| 91久久九九无码成人网站| 久久天天躁狠狠躁夜夜96流白浆| 亚洲欧美久久久久9999| 久久国产乱子伦精品免费强| 日本欧美久久久久免费播放网| 久久久久国产一区二区| 久久精品国产半推半就| 亚洲国产欧美国产综合久久 | 亚洲AV伊人久久青青草原| 久久精品国产99国产电影网 | 国产亚洲精品久久久久秋霞| 国内精品久久久久久不卡影院 | 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久精品a亚洲国产v高清不卡| 久久亚洲日韩看片无码| 亚洲国产成人乱码精品女人久久久不卡| 久久精品成人免费看| 一本久久久久久久| 99久久99久久精品国产片果冻| 中文精品久久久久国产网址| 国产亚洲精午夜久久久久久| 91精品国产91热久久久久福利| 91麻豆精品国产91久久久久久|