• <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!
            99re久久精品国产首页2020| 91超碰碰碰碰久久久久久综合| 久久久免费观成人影院 | 国产精品久久久久久福利69堂| 精品久久8x国产免费观看| 国产2021久久精品| 久久精品国产日本波多野结衣| 精品久久久久久| 久久精品国产亚洲AV忘忧草18| 国产精品一区二区久久精品| 久久久亚洲精品蜜桃臀| 久久不见久久见免费视频7| 久久久久久青草大香综合精品| 国产综合久久久久| 中文字幕久久亚洲一区| 51久久夜色精品国产| 久久综合给久久狠狠97色 | 青青热久久综合网伊人| 欧美午夜精品久久久久免费视 | 亚洲国产精品无码成人片久久| 精品99久久aaa一级毛片| 久久久噜噜噜久久熟女AA片| 久久99国产精品久久99小说| 伊人热人久久中文字幕| 国内精品伊人久久久久| 久久婷婷五月综合97色| 18岁日韩内射颜射午夜久久成人| 久久99精品久久久久久不卡| 久久99免费视频| 国产精品美女久久久m| 色综合久久久久久久久五月| 成人午夜精品无码区久久| 久久丫忘忧草产品| 中文无码久久精品| 久久www免费人成看片| 亚洲女久久久噜噜噜熟女| 午夜不卡久久精品无码免费| 久久综合给合久久狠狠狠97色69| 久久精品国产网红主播| av无码久久久久不卡免费网站| 久久精品国产亚洲AV麻豆网站 |