• <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
            99久久精品免费看国产一区二区三区 | 国产成年无码久久久久毛片| 精品九九久久国内精品| 久久精品国产亚洲网站| 久久伊人精品青青草原日本| 无码国内精品久久人妻麻豆按摩 | 91久久精品国产成人久久| 久久久WWW免费人成精品| 狠狠色丁香婷婷久久综合五月 | 99精品国产免费久久久久久下载| 久久精品国产亚洲AV影院| 99久久精品影院老鸭窝| 亚洲一区精品伊人久久伊人| 久久精品国产99久久久| 亚洲人AV永久一区二区三区久久 | A狠狠久久蜜臀婷色中文网| 久久久WWW成人| 久久综合九色综合精品| 亚洲中文字幕久久精品无码喷水| 欧美伊香蕉久久综合类网站| 一本久久a久久精品亚洲| 久久精品国产亚洲AV不卡| 国产成年无码久久久久毛片| 久久精品国产久精国产一老狼| 狠狠色伊人久久精品综合网| 日韩精品无码久久久久久| 亚洲伊人久久综合中文成人网| 99久久成人18免费网站| 久久亚洲AV成人无码电影| 久久99久国产麻精品66| 欧美成人免费观看久久| 久久精品人妻一区二区三区| 99久久免费国产精品热| 国产精品美女久久久久久2018| 久久久久久久久久久久久久| 亚洲国产综合久久天堂| 亚洲国产成人久久一区WWW| 久久精品国产欧美日韩| 老司机午夜网站国内精品久久久久久久久| 国产精品久久久久久久久| 91精品国产高清久久久久久91 |