• <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>

            POJ 2255

            這是一個(gè)樹(shù)的遍歷轉(zhuǎn)換問(wèn)題,已知樹(shù)的前序遍歷和中序遍歷,求出樹(shù)的后序遍歷。一開(kāi)始的想法是先利用前序遍歷和中序遍歷,構(gòu)造出二叉樹(shù),再對(duì)這個(gè)二叉樹(shù)進(jìn)行后序遍歷輸出但
             1 #include<stdio.h>
             2 #include<string.h>
             3 #include<stdlib.h>
             4 typedef struct node{
             5     char e;
             6     struct node *l,*r;
             7 }*tree;
             8 tree t;
             9 char s1[27],s2[27];
            10 tree create(int pa,int pb,int ia,int ib);
            11 void postorder(tree T);
            12 int main()
            13 {
            14     int len;
            15     while(scanf("%s%s",s1,s2) != EOF){
            16         len = strlen(s1);
            17         t = create(0,len-1,0,len-1);
            18         postorder(t);
            19         printf("\n");
            20     }
            21     system("pause");
            22     return 0;
            23 }
            24 tree create(int pa,int pb,int ia,int ib)
            25 {
            26     int i;
            27     tree T;
            28     if(pa <= pb && ia <= ib){
            29         T = (tree)malloc(sizeof(struct node));
            30         T->= s1[pa];
            31         for(i = ia;i <= ib;i++){
            32             if(s1[pa] == s2[i])break;
            33         }
            34         int len1 = i - ia;
            35         T->= create(pa+1,pa+len1,ia,i-1);
            36         T->= create(pa+len1+1,pb,i+1,ib);
            37     }
            38     else
            39         T = NULL;
            40     return T;
            41 }
            42 void postorder(tree T)
            43 {
            44     if(T != NULL){
            45         postorder(T->l);
            46         postorder(T->r);
            47         printf("%c",T->e);
            48     }
            49 }
            50 
            是后來(lái)在網(wǎng)上看到一些大牛的作法:直接利用遞歸,就可以后序輸出結(jié)果這
             1 #include<stdio.h>
             2 #include<string.h>
             3 #include<stdlib.h>
             4 char s1[27],s2[27];
             5 void createprint(int pa,int pb,int ia,int ib);
             6 int main()
             7 {
             8     int len;
             9     while(scanf("%s%s",s1,s2) != EOF){
            10         len = strlen(s1);
            11         createprint(0,len-1,0,len-1);
            12         printf("\n");
            13     }
            14     system("pause");
            15     return 0;
            16 }
            17 void createprint(int pa,int pb,int ia,int ib)
            18 {
            19     int i;
            20     if(pa == pb){
            21         printf("%c",s1[pa]);
            22         return;
            23     }
            24     if(pa > pb || ia > ib)return;
            25     for(i = ia;i <= ib;i++)
            26         if(s1[pa] == s2[i])break;
            27     int len1 = i - ia;
            28     createprint(pa+1,pa+len1,ia,i-1);
            29     createprint(pa+len1+1,pb,i+1,ib);
            30     printf("%c",s1[pa]);
            31 }
            32 
            是太巧妙了,可以省略掉建樹(shù)這一步。這道題的代碼雖然不長(zhǎng),也可以因此減少幾乎一半的代碼。我還得好好體會(huì)體會(huì)。

            posted on 2009-05-30 20:41 Johnnx 閱讀(330) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            導(dǎo)航

            <2009年6月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            統(tǒng)計(jì)

            常用鏈接

            留言簿(1)

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            一本久久免费视频| 久久青草国产精品一区| 久久国产欧美日韩精品| 亚洲av伊人久久综合密臀性色 | 婷婷久久综合九色综合98| 亚洲国产成人久久综合一| 亚洲日本va午夜中文字幕久久| 中文字幕乱码久久午夜| 国产亚洲色婷婷久久99精品91| 亚洲欧美一区二区三区久久| 国产欧美一区二区久久| 性做久久久久久久久老女人| 国产精品久久久久久福利69堂| 久久激情五月丁香伊人| 久久综合久久综合久久| 合区精品久久久中文字幕一区| 久久久久久亚洲Av无码精品专口| 狠狠人妻久久久久久综合蜜桃| 亚洲午夜无码久久久久| 久久久久免费视频| 狠狠久久亚洲欧美专区| 亚洲国产精品久久电影欧美| 久久久久久久综合日本| 亚洲国产成人久久综合一| 粉嫩小泬无遮挡久久久久久| 中文字幕乱码久久午夜| 久久人人爽人人爽人人片AV高清| 久久精品国产亚洲精品| 欧美精品一本久久男人的天堂 | 久久久久久久综合日本亚洲| 亚洲va久久久噜噜噜久久狠狠| 国产精品久久新婚兰兰| 亚洲国产成人乱码精品女人久久久不卡| 久久电影网2021| 国产精品久久久天天影视香蕉| 老司机国内精品久久久久| 久久精品国产只有精品2020| 青青草国产精品久久| 国产午夜福利精品久久| 精品久久久久久99人妻| 香港aa三级久久三级老师2021国产三级精品三级在 |