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

            我希望你是我獨(dú)家記憶

            一段永遠(yuǎn)封存的記憶,隨風(fēng)而去
            posts - 263, comments - 31, trackbacks - 0, articles - 3
               :: 首頁 :: 新隨筆 ::  :: 聚合  :: 管理

            P1717——標(biāo)號法

            Posted on 2008-09-10 19:02 Hero 閱讀(192) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
             1 //1717 Accepted 272K 47MS C++ 1048B PKU
             2 
             3 //第一個標(biāo)號法程序--不斷更新當(dāng)前能取得的組合數(shù)的最小翻轉(zhuǎn)次數(shù)
             4 
             5 #include <stdio.h>
             6 #include <string.h>
             7 #include <stdlib.h>
             8 
             9 const int INF = 1e9 ;
            10 const int size = 14000 ;
            11 
            12 int flag[size+100] ;
            13 int inn ;
            14 
            15 void process()
            16 {
            17     flag[0= 0 ;
            18     forint i=1; i<=size; i++ ) flag[i] = INF ;
            19 
            20     int inup, indn ; int sum = 0 ;
            21 
            22     forint i=1; i<=inn; i++ )
            23     {
            24         scanf( "%d %d"&inup, &indn ) ; sum += ( inup+indn ) ;
            25         forint k=sum; k>=0; k-- )
            26         {
            27             if( flag[k] != INF  )//如果當(dāng)前的值組合出來過
            28             {
            29                 int turns = flag[k] ;//得到當(dāng)前組合數(shù)所需要的反轉(zhuǎn)次數(shù)
            30                 flag[k] = INF ;//由于要更新--當(dāng)前組合數(shù)不存在了
            31 
            32                 //更新操作--如果下一個dn可以得到的值k+indn所需的次數(shù)比當(dāng)前大--更新
            33                 //以dn為基準(zhǔn)--k+indn更新時不需要+1
            34                 if( flag[k+indn] > turns )   flag[k+indn] = turns ;
            35                 if( flag[k+inup] > turns+1 ) flag[k+inup] = turns+1 ;
            36             }
            37         }
            38     }//標(biāo)號法更新
            39 
            40     //從中間開始向兩邊搜尋down可以翻轉(zhuǎn)最小次能夠得到的值
            41     int i, j ;
            42     for( i=sum/2,j=sum/2.0+0.5; INF==flag[i]&&INF==flag[j]; i--,j++ ) ;
            43 
            44     printf( "%d\n", flag[i]<flag[j]? flag[i]:flag[j] ) ;
            45 }
            46 
            47 int main()
            48 {
            49     while( scanf( "%d"&inn ) != EOF )
            50     {
            51         //input() ;
            52 
            53         process() ;
            54 
            55         //output() ;
            56     }
            57 
            58     return 0 ;
            59 }
            国产精品久久久久天天影视| 久久久久国色AV免费看图片| 人妻无码精品久久亚瑟影视| 久久夜色精品国产亚洲| …久久精品99久久香蕉国产| 久久国产香蕉一区精品| 人妻无码αv中文字幕久久| 久久精品国产99久久久香蕉| 天天爽天天狠久久久综合麻豆| 51久久夜色精品国产| 国产成人精品久久| 久久精品国产清自在天天线| 久久这里只有精品18| 亚洲乱码日产精品a级毛片久久| 国产高潮国产高潮久久久| 性高湖久久久久久久久AAAAA| 狠狠色丁香婷婷久久综合不卡| 欧美粉嫩小泬久久久久久久 | 久久精品这里热有精品| 国产精品乱码久久久久久软件| 久久综合中文字幕| 亚洲AV无码久久精品蜜桃| 香蕉99久久国产综合精品宅男自| 久久综合狠狠色综合伊人| 久久精品黄AA片一区二区三区| 亚洲一区精品伊人久久伊人| 精品久久久无码中文字幕| 精品久久久久久亚洲| 久久精品人人槡人妻人人玩AV| 亚洲AV日韩AV天堂久久| 人妻无码αv中文字幕久久琪琪布| 久久天天日天天操综合伊人av| 亚洲狠狠综合久久| 国产成人精品久久| 精品无码久久久久久久久久 | 99久久精品九九亚洲精品| 精品久久久久久无码专区| 狠狠色婷婷综合天天久久丁香| 精品久久久久久无码专区| 97久久香蕉国产线看观看| 狠狠狠色丁香婷婷综合久久俺|