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

            coreBugZJ

            此 blog 已棄。

            ONP - SPOJ 4. Transform the Expression

            Transform the algebraic expression with brackets into RPN form (Reverse Polish Notation). Two-argument operators: +, -, *, /, ^ (priority from the lowest to the highest), brackets ( ). Operands: only letters: a,b,...,z. Assume that there is only one RPN form (no expressions like a*b*c).

            Input

            t [the number of expressions <= 100]
            expression [length <= 400]
            [other expressions]
            

            Text grouped in [ ] does not appear in the input file.

            Output

            The expressions in RPN form, one per line.
            

            Example

            Input:
            3
            (a+(b*c))
            ((a+b)*(z+x))
            ((a+t)*((b+(a+c))^(c+d)))
            
            Output:
            abc*+
            ab+zx+*
            at+bac++cd+^*
             
             
            中綴轉(zhuǎn)后綴,用遞歸解決。
            lambda 很好用。
            LISP SBCL
             1(defconstant +max-len+ 420)
             2(defconstant +max-pri+ 123456789)
             3(defvar *str*)
             4(defvar *pri*)
             5
             6
             7(defun solve(le ri)
             8 (let ((min-pri +max-pri+)
             9       (cur-idx le)
            10       (min-idx +max-len+))
            11  (count -1 *pri* :key #'(lambda (x)
            12                          (when (> min-pri x)
            13                           (setf min-pri x)
            14                           (setf min-idx cur-idx))
            15                          (incf cur-idx))
            16                  :start le
            17                  :end   ri)
            18  (cond
            19   ((< min-pri +max-pri+)
            20    (solve le min-idx)
            21    (solve (1+ min-idx) ri)
            22    (write-char (elt *str* min-idx)))
            23   ((= min-pri +max-pri+)
            24    (write-string (remove #\( (remove #\) (subseq *str* le ri))))))))
            25
            26
            27(let ((num (read))
            28      (tot-pri 0))
            29 (dotimes (i num)
            30  (setf *str* (remove #\Space (read-line)))
            31  (setf *pri* (make-array +max-len+ :fill-pointer 0))
            32  (setf tot-pri 0)
            33  (count #\? *str* :key #'(lambda (x)
            34                           (cond
            35                            ((alpha-char-p x)
            36                             (vector-push +max-pri+ *pri*))
            37                            ((char= x #\+)
            38                             (vector-push (+ tot-pri 1*pri*))
            39                            ((char= x #\-)
            40                             (vector-push (+ tot-pri 2*pri*))
            41                            ((char= x #\*)
            42                             (vector-push (+ tot-pri 3*pri*))
            43                            ((char= x #\/)
            44                             (vector-push (+ tot-pri 4*pri*))
            45                            ((char= x #\^)
            46                             (vector-push (+ tot-pri 5*pri*))
            47                            ((char= x #\()
            48                             (incf tot-pri 6)
            49                             (vector-push +max-pri+ *pri*))
            50                            ((char= x #\))
            51                             (decf tot-pri 6)
            52                             (vector-push +max-pri+ *pri*))
            53                            (t 
            54                             (vector-push +max-pri+ *pri*)))
            55                           #\.))
            56  (solve 0 (length *str*))
            57  (fresh-line)))
            58
            59
             

            posted on 2012-02-19 10:34 coreBugZJ 閱讀(319) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ACMAlgorithmLisp

            97久久国产露脸精品国产| 女人香蕉久久**毛片精品| 久久久久久九九99精品| 亚洲一区中文字幕久久| 久久精品国产欧美日韩99热| 久久永久免费人妻精品下载| 久久99精品国产麻豆蜜芽| 中文字幕人妻色偷偷久久| 国内精品久久久久久不卡影院| 思思久久99热只有频精品66| 久久综合久久综合久久综合| 亚洲欧美成人综合久久久| 久久丝袜精品中文字幕| 久久精品国产半推半就| 无遮挡粉嫩小泬久久久久久久| 很黄很污的网站久久mimi色 | 久久亚洲精品人成综合网| 99久久综合狠狠综合久久| 97久久久精品综合88久久| 久久久久久精品无码人妻| 久久久精品久久久久久| 久久免费国产精品一区二区| 久久亚洲私人国产精品| 一本色道久久HEZYO无码| 久久久亚洲精品蜜桃臀| 国产精品成人无码久久久久久 | 久久精品中文字幕无码绿巨人| 久久久久亚洲AV综合波多野结衣 | 怡红院日本一道日本久久 | 亚洲精品第一综合99久久 | 久久99精品久久久久久动态图 | 久久精品亚洲精品国产色婷| 久久久久亚洲AV无码观看| 久久精品国产欧美日韩99热| 色8激情欧美成人久久综合电| 久久精品国产精品亜洲毛片| 国产精品美女久久久免费| 青青青伊人色综合久久| 国产精品欧美久久久久天天影视| 情人伊人久久综合亚洲| 国产福利电影一区二区三区久久老子无码午夜伦不 |