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

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評(píng)論 - 20, 引用 - 0
            數(shù)據(jù)加載中……

            TOJ 1135 Matrix Chain Multiplication

            很簡(jiǎn)單的題,給定N個(gè)矩陣,然后給出一系列運(yùn)算式,用括號(hào)來(lái)限制運(yùn)算,最后求一共進(jìn)行了多少次乘法運(yùn)算。
            R(m,s) 和Q(s,n)相乘,要進(jìn)行m*s*n次~
            處理運(yùn)算先后的時(shí)候,用棧實(shí)現(xiàn),即后進(jìn)先出就可以了。
            Sample Input:
            9
            A 50 10
            B 10 20
            C 20 5
            D 30 35
            E 35 15
            F 15 5
            G 5 10
            H 10 20
            I 20 25
            A
            B
            C
            (AA)
            (AB)
            (AC)
            (A(BC))
            ((AB)C)
            (((((DE)F)G)H)I)
            (D(E(F(G(HI)))))
            ((D(EF))((GH)I))
            Sample Outout:
            0
            0
            0
            error
            10000
            error
            3500
            15000
            40500
            47500
            15125
            Code:
            #include <iostream>
            #include 
            <cstdio>
            #include 
            <string>
            #include 
            <map>
            using namespace std;

            struct Matrx{
                    
            char id;
                    
            int x,y;
            }a[
            30];
            Matrx stack[
            100];
            int main()
            {
                    
            int i,j,k,n,ans;
                    
            bool flag;
                    map
            <char,int>mark;
                    scanf(
            "%d",&n);
                    
            for(i = 1;i <= n; i++){
                            cin 
            >> a[i].id;
                            scanf(
            "%d%d",&a[i].x,&a[i].y);
                            mark[a[i].id] 
            = i;
                    }
                    
            string str;
                    
            while(cin>>str){
                            ans 
            = 0; flag = true;
                            
            int len = str.length();
                            
            int head,tail;
                            head 
            = tail = 0;
                            
            for(i = 0;i <len; i++){
                                    
            if(str[i] == '(')
                                            
            continue;
                                    
            else if(str[i] == ')'){     //pop
                                            if(head == 1)
                                                    head 
            --;
                                            
            else if(head > 1){
                                                    
            int tx = stack[head-2].x;
                                                    
            int ty = stack[head-1].y;
                                                    
            if(stack[head-2].y != stack[head-1].x) flag = false;
                                                    ans 
            += stack[head-2].x*stack[head-2].y*stack[head-1].y;
                                                    head 
            -= 2;
                                                    stack[head].x 
            = tx;
                                                    stack[head
            ++].y = ty;
                                            }

                                    }
                                    
            else{        // push
                                            stack[head++= a[mark[str[i]]];

                                    }
                            }
                            
            if(!flag) printf("error\n");
                            
            else printf("%d\n",ans);
                    }
            }




            posted on 2010-06-12 22:10 M.J 閱讀(177) 評(píng)論(0)  編輯 收藏 引用


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


            a高清免费毛片久久| 久久99国产精品尤物| 久久久久人妻精品一区三寸蜜桃 | 99久久国产免费福利| 久久精品国产清自在天天线| 免费一级做a爰片久久毛片潮| 色欲av伊人久久大香线蕉影院| 亚洲国产香蕉人人爽成AV片久久| 人妻精品久久无码专区精东影业| 久久综合丁香激情久久| 麻豆AV一区二区三区久久| 日韩欧美亚洲综合久久影院d3| 亚洲?V乱码久久精品蜜桃| 久久精品嫩草影院| 久久免费美女视频| 久久亚洲精品无码VA大香大香| 久久久免费观成人影院| 国内精品久久久久影院优| 亚洲精品WWW久久久久久| 91精品国产91久久久久久| 久久久久亚洲av成人网人人软件 | 日本人妻丰满熟妇久久久久久| 熟妇人妻久久中文字幕| 亚洲欧美另类日本久久国产真实乱对白| 久久久久99精品成人片直播| 久久久噜噜噜久久中文福利| 亚洲天堂久久久| 青青草原精品99久久精品66| 久久婷婷五月综合成人D啪| 久久99国产精品久久| 久久婷婷五月综合色高清| 久久婷婷国产剧情内射白浆| 开心久久婷婷综合中文字幕| 久久93精品国产91久久综合| 内射无码专区久久亚洲| 国内精品久久久久久久涩爱| 一本大道久久a久久精品综合| 久久99久久99精品免视看动漫| 97久久婷婷五月综合色d啪蜜芽 | 色狠狠久久综合网| 久久99久久无码毛片一区二区|