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

            我希望你是我獨家記憶

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

            P1042——gone fish

            Posted on 2008-09-19 18:36 Hero 閱讀(163) 評論(0)  編輯 收藏 引用 所屬分類: 代碼如詩--ACM
              1 #include <stdio.h>
              2 #include <stdlib.h>
              3 #include <string.h>
              4 #include <algorithm>
              5 #include <iostream>
              6 using namespace std ;
              7 
              8 const int size = 30 ;
              9 
             10 int f[size], d[size], t[size] ;
             11 int laketime[size] ;
             12 int finaltime[size] ;
             13 
             14 struct Lake
             15 {
             16     int fish ;//可掉的魚的數(shù)量
             17     int num ;//該湖的序號
             18     friend bool operator<const Lake &a, const Lake &b ) ;
             19 };
             20 struct Lake lake[size] ;
             21 
             22 bool operator<const Lake &a, const Lake &b )
             23 {
             24     if( a.fish != b.fish ) return a.fish - b.fish < 0 ;
             25 
             26     return a.num - b.num > 0 ;
             27 }
             28 
             29 int inn, inh ;
             30 int maxfish ;
             31 
             32 void input() 
             33 {
             34     scanf( "%d"&inh ) ; inh = inh*60/5 ;
             35     forint i=1; i<=inn; i++ ) scanf( "%d"&f[i] ) ;
             36     forint i=1; i<=inn; i++ ) scanf( "%d"&d[i] ) ;
             37 
             38     forint i=1; i<inn; i++ ) scanf( "%d"&t[i] ) ;
             39 }
             40 
             41 void process()
             42 {
             43     maxfish = -1 ; int curfish ;
             44     forint nlake=1; nlake<=inn; nlake++ )
             45     {//枚舉湖的數(shù)量
             46         forint i=1; i<=inn; i++ ) 
             47         {
             48             lake[i].fish = f[i] ; lake[i].num = i ; laketime[i] = 0 ;
             49         }
             50         make_heap( lake+1, lake+1+nlake ) ;//構(gòu)造大頂堆
             51 
             52         memset( laketime, 0sizeof(laketime) ) ;
             53         curfish = 0 ; int maxi = inh ;
             54         forint i=1; i<nlake; i++ ) maxi -= t[i] ;
             55         forint i=1; i<=maxi; i++ )
             56         {
             57             //出堆--最值放在最后一個位置
             58             pop_heap( lake+1, lake+1+nlake ) ;
             59 
             60             int num = lake[1+nlake-1].num ;
             61             int fish = lake[1+nlake-1].fish ;
             62 
             63             curfish += fish ; laketime[num]++ ;
             64 
             65             lake[1+nlake-1].fish -= d[num] ;
             66             if( lake[1+nlake-1].fish < 0 ) lake[1+nlake-1].fish = 0 ;
             67 
             68             push_heap( lake+1, lake+1+nlake ) ;//入堆--重新調(diào)整
             69         }
             70 
             71         if( curfish > maxfish ) 
             72         {
             73             maxfish = curfish ;
             74             memcpy( finaltime, laketime, sizeof(finaltime) ) ;
             75             //for( int i=0; i<=inn; i++ ) finaltime[i] = laketime[i] ;
             76         }
             77     }
             78 }
             79 
             80 void output()
             81 {
             82     printf( "%d", finaltime[1]*5 ) ;
             83     forint i=2; i<=inn; i++ )
             84     {
             85         printf( ", %d", finaltime[i]*5  ) ;
             86     }
             87     printf( "\nNumber of fish expected: %d\n\n", maxfish ) ;
             88 }
             89 
             90 int main()
             91 {
             92     //freopen( "in.txt", "r", stdin ) ;
             93     //freopen( "out.txt", "w", stdout ) ;
             94 
             95     while( scanf( "%d"&inn ) != EOF && inn )
             96     {
             97         input() ;
             98 
             99         process() ;
            100 
            101         output() ;
            102     }
            103 
            104     return 0 ;
            105 }
            106 
            久久这里只精品99re66| 久久艹国产| 香蕉久久一区二区不卡无毒影院 | 精品久久久久久无码不卡| 国产99久久久国产精品小说| 久久66热人妻偷产精品9| 久久国产福利免费| 久久精品aⅴ无码中文字字幕不卡| 国产精品成人无码久久久久久 | 欧美精品一区二区久久| 久久国产精品-国产精品| 国产色综合久久无码有码| 精品国产乱码久久久久久浪潮| 久久久久亚洲av无码专区| 午夜精品久久久久久| 九九热久久免费视频| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久综合九色综合网站| 久久久久噜噜噜亚洲熟女综合| 青青草国产精品久久| 久久精品国产网红主播| 亚洲AV无码1区2区久久| 免费久久人人爽人人爽av| 色综合久久88色综合天天 | 国产精品熟女福利久久AV| 久久青草国产手机看片福利盒子| 久久综合狠狠综合久久综合88 | 久久久免费观成人影院| 国产呻吟久久久久久久92| 久久综合中文字幕| 国产成人精品久久亚洲| 久久国产免费观看精品| 久久国产精品成人免费| 久久香蕉一级毛片| 国产精品熟女福利久久AV| 久久99精品国产麻豆不卡| 久久久黄片| 久久婷婷五月综合色奶水99啪| 少妇无套内谢久久久久| 亚洲AV成人无码久久精品老人| 久久精品国产亚洲av日韩|