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

            The Fourth Dimension Space

            枯葉北風(fēng)寒,忽然年以殘,念往昔,語(yǔ)默心酸。二十光陰無一物,韶光賤,寐難安; 不畏形影單,道途阻且慢,哪曲折,如渡飛湍。斬浪劈波酬壯志,同把酒,共言歡! -如夢(mèng)令

            POJ 1179 多邊形游戲 區(qū)間動(dòng)規(guī)

            實(shí)際上就是枚舉所有區(qū)間,求出所有區(qū)間可以獲得的最大值和最小值,區(qū)間L的的結(jié)果可以由區(qū)間L-1的結(jié)果組合得到。
            這題有一個(gè)小技巧很好用,就是求第i個(gè)結(jié)點(diǎn)順時(shí)針向后的第t個(gè)結(jié)點(diǎn)如果是node(i,t)的話,那么node (i,t+1)的標(biāo)號(hào)可以由
            ((i+t)%n )+1得到,實(shí)際上lebel[node(i,t)]=((i+t-1)%n )+1;所以這題結(jié)點(diǎn)從1開始存似乎更加便于計(jì)算。
            //coded by abilitytao
            //2010年6月1日17:25:38
            #include <iostream>
            #include
            <algorithm>
            #include
            <cmath>
            using namespace std;
            const int maxn=100;

            int n;
            int fmax[maxn][maxn];
            int fmin[maxn][maxn];
            int v[maxn];
            int op[maxn];
            void init()//初始化
            {

                
            for(int i=1;i<=n;i++)
                    
            for(int j=1;j<=n;j++)
                    
            {
                        fmax[i][j]
            =-999999999;
                        fmin[i][j]
            =999999999;
                    }

                    
            for(int i=1;i<=n;i++)
                        fmax[i][
            0]=fmin[i][0]=v[i];
            }


            void input()
            {

                scanf(
            "%d",&n);
                cin.ignore();
                
            int i;
                
            for(i=1;i<=n;i++)
                
            {
                    
            char tem[10];
                    scanf(
            "%s",tem);
                    
            if(tem[0]=='t')
                        op[i]
            =0;//0代表+號(hào)
                    else
                        op[i]
            =1;//1代表乘號(hào)
                    scanf("%d",&v[i]);
                }

            }



            void solve()//DP過程
            {
                
            int mm=-999999999;
                
            int i,t,L;
                
            for(L=1;L<=n-1;L++)
                
            {
                    
            for(i=1;i<=n;i++)
                    
            {
                        
            for(t=0;t<=L-1;t++)
                        
            {

                            
            if(op[(i+t)%n+1]==0)
                            
            {
                                fmin[i][L]
            =min(fmin[i][L],fmin[i][t]+fmin[(i+t)%n+1][L-t-1]);
                                fmax[i][L]
            =max(fmax[i][L],fmax[i][t]+fmax[(i+t)%n+1][L-t-1]);
                            }

                            
            else
                            
            {
                                fmin[i][L]
            =min(fmin[i][L],fmin[i][t]*fmin[(i+t)%n+1][L-t-1]);
                                fmin[i][L]
            =min(fmin[i][L],fmin[i][t]*fmax[(i+t)%n+1][L-t-1]);
                                fmin[i][L]
            =min(fmin[i][L],fmax[i][t]*fmin[(i+t)%n+1][L-t-1]);
                                fmin[i][L]
            =min(fmin[i][L],fmax[i][t]*fmax[(i+t)%n+1][L-t-1]);

                                fmax[i][L]
            =max(fmax[i][L],fmin[i][t]*fmin[(i+t)%n+1][L-t-1]);
                                fmax[i][L]
            =max(fmax[i][L],fmin[i][t]*fmax[(i+t)%n+1][L-t-1]);
                                fmax[i][L]
            =max(fmax[i][L],fmax[i][t]*fmin[(i+t)%n+1][L-t-1]);
                                fmax[i][L]
            =max(fmax[i][L],fmax[i][t]*fmax[(i+t)%n+1][L-t-1]);
                            }

                        }

                    }

                }

                
            for(i=1;i<=n;i++)
                    
            if(fmax[i][n-1]>mm)
                        mm
            =fmax[i][n-1];
                printf(
            "%d\n",mm);
                
            for(i=1;i<=n;i++)
                    
            if(fmax[i][n-1]==mm)
                        printf(
            "%d ",i);
                printf(
            "\n");
            }


            int main()
            {
                input();
                init();
                solve();
                
            return 0;
            }

            posted on 2010-06-01 17:26 abilitytao 閱讀(2092) 評(píng)論(0)  編輯 收藏 引用


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


            精品久久久一二三区| 亚洲精品成人久久久| 久久精品国产亚洲AV无码偷窥| 青青草国产97免久久费观看| 久久无码精品一区二区三区| 久久久亚洲裙底偷窥综合| 久久成人国产精品| 国内精品伊人久久久久影院对白| 久久九九久精品国产免费直播| 久久亚洲AV无码精品色午夜| 久久天堂AV综合合色蜜桃网| 久久高清一级毛片| 久久99精品国产麻豆| 色8激情欧美成人久久综合电| 久久国产精品无码一区二区三区| 丰满少妇人妻久久久久久4| 免费无码国产欧美久久18| 中文字幕久久欲求不满| 无码精品久久久天天影视| 日本久久中文字幕| 久久电影网2021| 久久精品人人做人人爽电影蜜月| 欧美激情精品久久久久久久九九九 | 国产精品久久久久影院色| 亚洲国产精品无码久久青草| 久久线看观看精品香蕉国产| 久久久久亚洲av无码专区 | 一本色道久久88精品综合| 久久精品国产精品亜洲毛片| 精品久久久久久无码中文字幕一区| 伊人久久精品影院| 久久一本综合| 久久精品国产福利国产琪琪| 国产精品亚洲美女久久久| 久久夜色精品国产亚洲| 热99re久久国超精品首页| 久久国产精品成人片免费| 久久精品国产亚洲AV无码偷窥| 九九久久自然熟的香蕉图片| 狼狼综合久久久久综合网| 久久发布国产伦子伦精品|