• <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精品国产麻豆蜜芽| 国内精品伊人久久久影院| 国产精品伦理久久久久久| 99精品国产综合久久久久五月天| av国内精品久久久久影院| 日日狠狠久久偷偷色综合免费| 久久精品国产亚洲AV香蕉| 亚洲AV日韩精品久久久久久| 久久经典免费视频| 亚洲色欲久久久综合网| 亚洲AV日韩精品久久久久| 色婷婷久久综合中文久久蜜桃av | 99久久成人18免费网站| 久久亚洲AV成人出白浆无码国产| 欧美亚洲国产精品久久| 久久99久久99精品免视看动漫| 亚洲国产成人久久精品99 | 色综合久久天天综合| 成人免费网站久久久| 久久99精品国产麻豆宅宅| 精品免费久久久久国产一区| 久久久91人妻无码精品蜜桃HD| 久久亚洲欧洲国产综合| 久久精品国产精品亚洲精品| 日韩久久久久久中文人妻| 亚洲国产精品久久久久婷婷软件| 少妇被又大又粗又爽毛片久久黑人| 久久精品人妻中文系列| 777久久精品一区二区三区无码| 国产精品久久久久一区二区三区 | 久久这里只精品99re66| 午夜视频久久久久一区| 中文精品久久久久人妻不卡| 内射无码专区久久亚洲| 亚洲∧v久久久无码精品| 久久中文字幕人妻熟av女| 久久免费高清视频| 秋霞久久国产精品电影院| 精品久久一区二区三区| 久久99国产乱子伦精品免费| 久久久无码人妻精品无码|