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

            PKU 1239 Increasing Sequences 二次DP (重點(diǎn))

            題意很清楚,對(duì)一個(gè)數(shù)字(80位),進(jìn)行劃分,形成若干段,使得這些數(shù)字嚴(yán)格遞增,使得最后一個(gè)數(shù)字最小。如果有重復(fù),優(yōu)先輸出第一個(gè)數(shù)最大的方案,如果還有重復(fù),則第二個(gè)數(shù)字最大,以此類(lèi)推~
            好吧,以此DP,從前向后掃描可以確定最后一個(gè)數(shù)字最小的方案。為了解決重復(fù),需要再次用DP構(gòu)造解(以往很多題目都是用貪心直接在第一次DP中構(gòu)造解),即解決這樣一個(gè)自問(wèn)題,在最后一段數(shù)字確定的情況下第一段數(shù)字最大值是多少。做法和第一次DP類(lèi)似,只不過(guò)從后向前掃描。
            貼代碼
             1 import java.io.*;
             2 import java.math.*;
             3 import java.util.*;
             4 public class Main {
             5 
             6     /**
             7      * @param args
             8      */
             9 
            10     public static void main(String[] args) throws IOException{
            11         BufferedReader in=new BufferedReader(new InputStreamReader(System.in));
            12         BigInteger arr[]=new BigInteger[100];
            13         int path[]=new int[101];
            14         
            15         String str;
            16         while(true)
            17         {
            18             str=in.readLine();
            19             Arrays.fill(path,-1);
            20             if(str.equals("0")) break;
            21             for(int i=0;i<str.length();i++)
            22                 arr[i]=new BigInteger(str.substring(0, i+1));
            23 
            24                 for(int i=0;i<str.length();i++)
            25                     for(int j=i-1;j>=0;j--)
            26                     {
            27                         BigInteger tmp=new BigInteger(str.substring(j+1,i+1));
            28                         if(tmp.compareTo(arr[j])>0&&tmp.compareTo(arr[i])<0)
            29                             arr[i]=tmp;
            30                     }
            31             BigInteger target=arr[str.length()-1];
            32             Arrays.fill(arr, null);
            33             for(int i=str.length()-1;i>=0;i--)
            34                 if(target.equals(new BigInteger(str.substring(i))))
            35                     arr[i]=target;
            36             for(int i=str.length()-1;i>=0;i--)
            37                 for(int j=i;j<str.length()-1;j++)
            38                 {
            39                     BigInteger tmp=new BigInteger(str.substring(i,j+1));
            40                     if(arr[j+1]!=null&&tmp.compareTo(arr[j+1])<0&&(arr[i]==null||arr[i].compareTo(tmp)<0)) 
            41                         {
            42                            arr[i]=tmp;
            43                            path[i]=j;
            44                         }
            45                 }
            46             int p=0;
            47             while(true)
            48             {
            49                 if(path[p]==-1)
            50                 {
            51                     System.out.println((p==0?"":",")+str.substring(p));
            52                     break;
            53                 }
            54                 else if(p==0)
            55                     System.out.print(str.substring(p,path[p]+1));
            56                 else 
            57                     System.out.print(","+str.substring(p,path[p]+1));
            58                 p=path[p]+1;
            59             }
            60             
            61         }
            62 
            63     }
            64 
            65 }
            66 

            posted on 2010-10-25 21:07 yzhw 閱讀(280) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): DP

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            統(tǒng)計(jì)系統(tǒng)

            留言簿(1)

            隨筆分類(lèi)(227)

            文章分類(lèi)(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            狠狠色噜噜色狠狠狠综合久久| 91久久成人免费| 理论片午午伦夜理片久久| 国产999精品久久久久久| 久久精品国产99久久香蕉| 91麻豆国产精品91久久久| 久久男人Av资源网站无码软件| 亚洲国产成人久久精品动漫| 久久一区二区三区99| 色婷婷综合久久久久中文| 国产麻豆精品久久一二三| 一级做a爱片久久毛片| 欧美国产精品久久高清| 久久久久国产精品熟女影院| 久久久久亚洲精品中文字幕| 亚洲精品99久久久久中文字幕| 亚洲中文字幕无码久久精品1| 99久久er这里只有精品18| 久久WWW免费人成—看片| 久久久精品久久久久久| 伊人久久大香线蕉综合Av| 久久久久久亚洲精品不卡| 国内精品久久国产大陆| 亚洲国产精品一区二区久久hs| 久久男人中文字幕资源站| 久久精品国产99国产电影网 | 亚洲天堂久久精品| 国内精品久久久久久久久电影网| 久久久久久极精品久久久| 一本一道久久精品综合| 久久综合欧美成人| 久久亚洲综合色一区二区三区| 久久国产色AV免费观看| 青草国产精品久久久久久 | 久久这里只有精品18| 婷婷久久综合九色综合九七| 国产精品成人久久久久三级午夜电影| 72种姿势欧美久久久久大黄蕉| 亚洲午夜久久久影院| 久久天天躁狠狠躁夜夜不卡| 精品久久人人妻人人做精品|