• <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 
            99久久国产综合精品五月天喷水| 伊人久久大香线蕉精品| 国产高潮国产高潮久久久91| 久久久久一级精品亚洲国产成人综合AV区 | 国产精品成人久久久久久久| 久久精品一区二区国产| 久久久久无码精品国产app| 久久精品国产日本波多野结衣| 国产ww久久久久久久久久| 香蕉久久av一区二区三区| 污污内射久久一区二区欧美日韩| 久久亚洲春色中文字幕久久久| 久久久精品波多野结衣| 国产激情久久久久影院小草| 久久99精品久久久久久齐齐| 狠狠色婷婷综合天天久久丁香 | 久久精品视屏| 欧美国产成人久久精品| 久久精品三级视频| 蜜桃麻豆www久久| 国产精品久久久久乳精品爆| AV无码久久久久不卡蜜桃 | 久久久精品国产sm调教网站| 日韩欧美亚洲国产精品字幕久久久| 99精品国产在热久久| 久久精品国产亚洲AV香蕉| 精品久久久久久无码人妻热 | 亚洲AⅤ优女AV综合久久久| 精品久久一区二区三区| 欧美亚洲国产精品久久久久| 久久精品国产亚洲av麻豆蜜芽 | 伊人久久无码精品中文字幕| 天天影视色香欲综合久久| 亚洲级αV无码毛片久久精品| 日产精品久久久久久久性色| 久久精品国产清自在天天线| 少妇人妻88久久中文字幕| 久久99精品久久久久久野外| 久久综合精品国产一区二区三区| 国产综合免费精品久久久| 久久精品无码一区二区日韩AV|