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

            infinity

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              36 隨筆 :: 0 文章 :: 25 評論 :: 0 Trackbacks
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1179
            dp題,寫起來還是有一點麻煩。
            方法:
            用數組num記錄各頂點的值,op[i][j]記錄點i和點j之間的運算符;
            把num數組擴展一倍(類似石子合并的做法),然后枚舉起點i(i到n),也就是相當與move掉線段 i-1。注意可
            能有負負的正的情況,所以還要記錄最大最小值。F[i][j][0] imps min,F[i][j][1] imps max;狀態轉移方程
            F[i][j][]=max{F[i][k][] op F[k+1][j][]}{i=<k<j};
            枚舉起點i即可;

            Source Code

            Problem: 1179
            User: lovecanon
            Memory: 296K
            Time: 94MS
            Language: C++
            Result: Accepted



            #include<stdio.h>
            #include
            <string.h>
            #include
            <stdlib.h>
            char op[102][102];
            int val[102][102][2],num[102],tmp[4],ans[102],top;
            int min(int a,int b){if(a<=b) return a;else return b;}
            int max(int a,int b){if(a>=b) return a;else return b;}
            int cmp(const void *a,const void *b){
                
            return *(int *)a-*(int *)b;
            }
            int main(){
                
            int n,i,j,k,l,m;
                scanf(
            "%d",&n);
                scanf(
            "%*c%c%*c%d",&op[n][n+1],&num[1]);
                num[n
            +1]=num[1];
                
            for(i=2;i<=n;i++){
                    scanf(
            "%*c%c%*c%d",&op[i-1][i],&num[i]);
                    op[i
            -1+n][i+n]=op[i-1][i];
                    num[i
            +n]=num[i];
                }
                
            /*
                for(i=1;i<=2*n-1;i++)
                    printf("%d%c",num[i],op[i][i+1]);
                
            */
                
            //pre-process
                memset(val,0,sizeof(val));
                
            for(i=1;i<=2*n;i++) val[i][i][0]=val[i][i][1]=num[i];
                
                
            int MAX=-100000000;
                top
            =0;
                
            for(i=1;i<=n;i++){//enumerate the edge moved bettween Vi-1 & Vi
                    for(l=1;l<=n-1;l++){//l is the difference bettween j & k
                        for(j=i;j<=n+i-1-l;j++){//enumerate the start point j 
                            k=j+l;
                            
            //intervla bettween Vj && Vk
                            int max=-100000000,min=100000000;
                            
            for(m=j;m<k;m++){
                                
            int cnt;
                                
            if(op[m][m+1]=='x'){// op="*"
                                    if(val[j][m][0]<0 || val[j][m][1]<0 || val[m+1][k][0]<0 || val[m+1][k][1]<0){
                                        
            //由于可能出現負負的正的情況,就比較復雜了,因此
                                        
            //我直接將4個值排序取大小 
                                        tmp[0]=val[j][m][0]*val[m+1][k][0];
                                        tmp[
            1]=val[j][m][0]*val[m+1][k][1];
                                        tmp[
            2]=val[j][m][1]*val[m+1][k][0];
                                        tmp[
            3]=val[j][m][1]*val[m+1][k][1];
                                        qsort(tmp,
            4,sizeof(tmp[0]),cmp);
                                        
            if(tmp[0]<min) min=tmp[0];//min 
                                        if(tmp[3]>max) max=tmp[3];//max
                                    }
                                    
            else{
                                        
            if((cnt=val[j][m][0]*val[m+1][k][0])<min) min=cnt;
                                        
            if((cnt=val[j][m][1]*val[m+1][k][1])>max) max=cnt;
                                    }
                                }
                                
            else{//op="+"
                                    if((cnt=val[j][m][0]+val[m+1][k][0])<min) min=cnt;
                                    
            if((cnt=val[j][m][1]+val[m+1][k][1])>max) max=cnt;
                                }
                            }
            //endfor m
                            val[j][k][0]=min;
                            val[j][k][
            1]=max;
                        }
            //endfor j
                    }//endfor l
                    
                    
            //用一個棧保存結果,比較方便 
                    if(val[i][i+n-1][1]>MAX){
                        MAX
            =val[i][i+n-1][1];
                        top
            =0;
                        ans[
            ++top]=i;
                    }
                    
            else if(val[i][i+n-1][1]==MAX) ans[++top]=i;
                    
                }
            //endfor i
                printf("%d\n",MAX);
                
            for(i=1;i<=top;i++) printf("%d ",ans[i]);
                printf(
            "\n");
                
            //system("pause");
                return 0;
            }

            posted on 2008-11-15 13:39 infinity 閱讀(792) 評論(0)  編輯 收藏 引用 所屬分類: acm
            国产精品久久久亚洲| 久久精品国产亚洲一区二区| 久久99国产亚洲高清观看首页 | 91精品国产91久久综合| 亚洲va久久久噜噜噜久久| 久久综合久久美利坚合众国| 一本久久知道综合久久| 国产L精品国产亚洲区久久| 久久笫一福利免费导航| 久久久久国产一区二区| 久久香蕉国产线看观看99| 久久无码AV中文出轨人妻| 久久er国产精品免费观看2| 久久男人中文字幕资源站| 久久精品国产亚洲综合色| 久久受www免费人成_看片中文| 久久成人国产精品二三区| 久久婷婷五月综合国产尤物app| 精品多毛少妇人妻AV免费久久| 久久久久人妻一区二区三区 | 久久青草国产精品一区| 东方aⅴ免费观看久久av| 国产激情久久久久影院小草 | 久久久久久国产精品美女| 精品午夜久久福利大片| 99久久国产综合精品麻豆| .精品久久久麻豆国产精品| 99久久99久久精品国产片果冻| 狠狠人妻久久久久久综合| 国内精品伊人久久久久网站| 国内精品久久久久久久久电影网| 浪潮AV色综合久久天堂| 久久免费视频6| 久久亚洲欧美日本精品| 精品久久人人妻人人做精品 | 久久综合给合久久国产免费| 91秦先生久久久久久久| 久久精品国产99久久无毒不卡| 77777亚洲午夜久久多喷| 久久经典免费视频| 久久99精品国产麻豆宅宅|