• <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>
            小山日志
            讀書,學習與思考.
            posts - 9,comments - 14,trackbacks - 0
            ??? 這是嚴蔚敏《數據結構》配套習題冊上的題目:將逆波蘭式轉換成波蘭式,并提示錯誤(作為簡化,只處理"+-*/"和0~9的數字)。
            ??? 例如:"123*-"轉換成波蘭式為"-1*23"
            ??? 逆波蘭式"123*-"的表達式樹如下:
            ??? 所以這個轉換過程就是:已知一個二叉樹的后根遍歷序列,求先根遍歷序列。
            ??? 我的算法是根據后根遍歷的序列構造一個表達式樹,進而先根遍歷此樹獲得波蘭式表達式。
            ??? 定義了兩個結構體:
            struct?Exp{
            ????
            char??op;
            ????Item??lhs;
            ????Item??rhs;
            ????Exp(){};
            ????Exp(
            char?_op,?Item?_lhs,?Item?_rhs):op(_op),?lhs(_lhs),?rhs(_rhs){?}
            ????Exp(
            const?Exp&?e):op(e.op),?lhs(e.lhs),?rhs(e.rhs)?{?}
            };

            表示一個表達式,也是表達式樹上的一個子樹。
            struct?Item{
            ????
            char??number;
            ????shared_ptr
            <Exp>?pExp;
            ????
            bool?isNumber;
            ????
            explicit?Item():isNumber(true),?number('0'),?pExp(){????}
            ????Item(
            const?Item&?i):number(i.number),?pExp(i.pExp),?isNumber(i.isNumber){?}
            };


            表示一個節點,它可以是一個數字,或者一個表達式(pExp這里我使用的是boost庫的智能指針shared_ptr,所以編譯的話,需要先安裝boost庫)。
            運行的結果如圖:

            *輸入時,以'e'表示輸入結束。
            完整的代碼和可執行文件點擊這里下載。權當拋磚引玉了,希望有更好算法的同學賜教。


            完整的代碼:
            posted on 2006-12-05 14:45 小山日志 閱讀(2202) 評論(0)  編輯 收藏 引用 所屬分類: Aha! Algorithm!
            国产精品99久久久精品无码| 粉嫩小泬无遮挡久久久久久| 久久性生大片免费观看性| 色婷婷久久综合中文久久一本| 久久精品一区二区三区AV| 国产精品久久99| 亚洲欧洲精品成人久久奇米网| 久久久久亚洲av无码专区导航 | 久久青草国产精品一区| 蜜桃麻豆www久久国产精品| 久久婷婷激情综合色综合俺也去| 亚洲精品国产成人99久久| 精品久久久久久国产| 久久久久国产视频电影| 国产精品99久久免费观看| 久久国产色av免费看| 久久婷婷色香五月综合激情| segui久久国产精品| 精品无码久久久久久尤物| 99久久精品国产一区二区| 亚洲精品美女久久久久99小说| 91精品久久久久久无码| avtt天堂网久久精品| 亚洲精品乱码久久久久久久久久久久 | 久久精品国产亚洲欧美| 久久天天躁狠狠躁夜夜avapp| 性做久久久久久久久老女人| 亚洲精品国产成人99久久| 久久精品国产一区二区三区日韩| 久久发布国产伦子伦精品| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久毛片免费看一区二区三区| 狠狠色丁香婷婷久久综合不卡| 久久久免费精品re6| www.久久热.com| 久久精品国产亚洲欧美| 热久久这里只有精品| 久久人人爽人爽人人爽av| 日韩AV毛片精品久久久| 伊人久久大香线蕉亚洲| 国产99精品久久|