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

            oyjpArt ACM/ICPC算法程序設計空間

            // I am new in programming, welcome to my blog
            I am oyjpart(alpc12, 四城)
            posts - 224, comments - 694, trackbacks - 0, articles - 6

            說題~

            Posted on 2008-08-17 10:09 oyjpart 閱讀(2733) 評論(1)  編輯 收藏 引用 所屬分類: ACM/ICPC或其他比賽

            PKU2690 Yahtzee

            用搜索做,超時,郁悶。

            正解:動態規劃。

            DP狀態:dp[mask][i], mask代表用了多少種方案了,i代表前6種方案的得分。

            因為前6種方式得分和超過63有加分,因此這一維是必須的。

            DP向后推比較好寫。

            核心代碼:

                memset(dp, -1sizeof(dp));
                dp[
            0][0= 0;
                pre[
            0][0][0= -1;
                
            for(j = 0; j < (1<<13); ++j) {
                    
            int round = ones(j);
                    
            for(k = 0; k < 126++k) if(dp[j][k] != -1) {
                        
            for(o = 1; o < 14++o) if(!(j&(1<<(o-1)))) {
                            
            int add = 0;
                            
            if(o <= 6) add = s[round][o];
                            
            if(dp[j|(1<<(o-1))][k+add] < dp[j][k] + s[round][o]) {
                                dp[j
            |(1<<(o-1))][k+add] = dp[j][k] + s[round][o];
                                pre[j
            |(1<<(o-1))][k+add][0= o;
                                pre[j
            |(1<<(o-1))][k+add][1= s[round][o];
                            }
                        }
                    }
                }
                
            int max = -1, maxa = -1, maxb = -1, maxk; 
                
            for(i = 0; i < (1<<13); ++i) {
                    
            for(k = 0; k < 126++k) {
                        
            int now = dp[i][k];
                        
            if(k >= 63) now += 35;
                        
            if(now > max) {
                            max 
            = now;
                            maxa 
            = i;
                            maxb 
            = k;
                            
            if(k >= 63) maxk = 35;
                            
            else maxk = 0;        
                        }
                    }
                }


            Feedback

            # re: 說題~  回復  更多評論   

            2008-08-17 17:37 by dell筆記本
            我給存起來了,以后要是能變成一本電子書就好了。
            精品久久久久久中文字幕大豆网| 精品免费久久久久国产一区| 亚洲国产成人精品女人久久久 | 国内精品久久久久久久coent| 精品欧美一区二区三区久久久| 欧美久久久久久| 国产午夜电影久久| 久久国产精品一国产精品金尊| 国产精品亚洲综合久久| 久久精品无码一区二区三区日韩 | 久久亚洲AV永久无码精品| 青青青国产精品国产精品久久久久| 久久久久波多野结衣高潮| 久久99热狠狠色精品一区| 久久99免费视频| 亚洲中文字幕无码久久2017| 亚洲国产美女精品久久久久∴ | 久久人妻少妇嫩草AV无码专区| 国内精品伊人久久久久| 国内精品久久久久影院薰衣草| 99久久国产综合精品成人影院| 国产精品久久久久久久久免费| 久久国产亚洲精品无码| yy6080久久| 最新久久免费视频| 久久丫精品国产亚洲av| 精品久久777| 久久精品国产亚洲AV大全| 色妞色综合久久夜夜| 久久久高清免费视频| 午夜精品久久久久成人| 欧美性猛交xxxx免费看久久久| 99热精品久久只有精品| 久久综合欧美成人| 久久亚洲综合色一区二区三区| 精品久久久久久无码专区不卡| 66精品综合久久久久久久| www.久久热| 久久久久久A亚洲欧洲AV冫| 久久久久亚洲AV成人网| 久久久久亚洲爆乳少妇无|