• <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 閱讀(774) 評論(0)  編輯 收藏 引用 所屬分類: acm
            久久人人爽人人爽人人AV东京热| 久久久人妻精品无码一区| 久久综合给合久久狠狠狠97色| 久久久亚洲欧洲日产国码二区 | 亚洲国产精品久久久久婷婷软件| 国产AⅤ精品一区二区三区久久| 久久久久久亚洲精品不卡| 无码任你躁久久久久久| 99久久精品国产免看国产一区| 久久久久九国产精品| 久久精品成人免费看| 色妞色综合久久夜夜| AA级片免费看视频久久| 久久亚洲欧美国产精品| 天堂无码久久综合东京热| 中文字幕久久欲求不满| 久久精品无码午夜福利理论片 | 国产成人精品久久二区二区| 国内精品伊人久久久久妇| 久久精品成人| 久久国产香蕉视频| 狠狠综合久久综合中文88| 久久精品蜜芽亚洲国产AV| 亚洲国产精品无码久久久秋霞2 | 久久青青草原精品影院| 色诱久久久久综合网ywww| 久久人妻AV中文字幕| 香蕉久久夜色精品国产尤物| 久久久久99精品成人片三人毛片 | 久久人人爽人人爽人人片av麻烦| 久久se精品一区二区影院| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 亚洲精品蜜桃久久久久久| 亚洲欧美日韩中文久久| 久久精品国产免费观看| 欧美大香线蕉线伊人久久| 久久99精品久久久久久hb无码| 亚洲熟妇无码另类久久久| 久久国产劲爆AV内射—百度| 亚洲国产另类久久久精品小说| 少妇精品久久久一区二区三区|