• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              36 隨筆 :: 0 文章 :: 25 評論 :: 0 Trackbacks
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1179
            dp題,寫起來還是有一點(diǎn)麻煩。
            方法:
            用數(shù)組num記錄各頂點(diǎn)的值,op[i][j]記錄點(diǎn)i和點(diǎn)j之間的運(yùn)算符;
            把num數(shù)組擴(kuò)展一倍(類似石子合并的做法),然后枚舉起點(diǎn)i(i到n),也就是相當(dāng)與move掉線段 i-1。注意可
            能有負(fù)負(fù)的正的情況,所以還要記錄最大最小值。F[i][j][0] imps min,F[i][j][1] imps max;狀態(tài)轉(zhuǎn)移方程
            F[i][j][]=max{F[i][k][] op F[k+1][j][]}{i=<k<j};
            枚舉起點(diǎn)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){
                                        
            //由于可能出現(xiàn)負(fù)負(fù)的正的情況,就比較復(fù)雜了,因此
                                        
            //我直接將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
                    
                    
            //用一個棧保存結(jié)果,比較方便 
                    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国内精品自在现线| 精品国产乱码久久久久久1区2区| 合区精品久久久中文字幕一区| 久久国产精品99精品国产987| 久久精品国产亚洲αv忘忧草 | 91精品无码久久久久久五月天| 亚洲色欲久久久综合网东京热| 2021国产精品午夜久久| 久久久SS麻豆欧美国产日韩| 久久婷婷五月综合97色直播 | 久久精品国产亚洲AV无码麻豆 | 日本福利片国产午夜久久| 国产精品久久精品| 99久久精品无码一区二区毛片| 国产免费久久久久久无码| 久久国产午夜精品一区二区三区| 久久久久无码国产精品不卡| 亚洲欧美国产精品专区久久| 精品一二三区久久aaa片| 国产99久久精品一区二区| 伊人久久精品线影院| 久久久久久青草大香综合精品| 国产香蕉久久精品综合网| 久久夜色精品国产网站| 成人亚洲欧美久久久久| 久久人人爽人人爽人人片AV不| 久久se精品一区精品二区| 亚洲精品美女久久久久99小说| 久久综合香蕉国产蜜臀AV| 中文字幕一区二区三区久久网站| 国产精品嫩草影院久久| 国产69精品久久久久久人妻精品| 久久国产精品久久久| 伊人精品久久久久7777| 狠狠狠色丁香婷婷综合久久俺| 中文成人久久久久影院免费观看 | 国内精品伊人久久久久妇| 久久精品亚洲中文字幕无码麻豆| 久久久久久国产精品免费免费| 亚洲AV成人无码久久精品老人|