• <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 ;//可掉的魚的數量
             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     {//枚舉湖的數量
             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 ) ;//構造大頂堆
             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 ) ;//入堆--重新調整
             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 
            久久久久国产日韩精品网站| 日韩人妻无码精品久久久不卡| 精品熟女少妇aⅴ免费久久| 久久久久久国产精品无码下载| 久久无码中文字幕东京热| 热re99久久精品国产99热| 国产午夜精品理论片久久| 一本久久知道综合久久| 久久精品一区二区影院| 久久99国内精品自在现线| 久久99精品国产麻豆婷婷| 青草国产精品久久久久久| 三级韩国一区久久二区综合 | 久久夜色tv网站| 精品久久亚洲中文无码| 精品免费久久久久国产一区| 久久久久久国产精品免费无码| 一本大道久久香蕉成人网| 亚洲天堂久久精品| 国产精品一区二区久久| 久久99国产精品久久99小说 | 久久噜噜电影你懂的| 久久精品国产久精国产果冻传媒| 久久精品国产欧美日韩| 国产精品嫩草影院久久| 国产精品美女久久久久AV福利| .精品久久久麻豆国产精品| 国产精品一区二区久久国产| 久久亚洲私人国产精品vA | 久久免费国产精品一区二区| 国产精品99久久免费观看| 人妻无码αv中文字幕久久琪琪布| 99久久精品免费看国产一区二区三区| 久久久久亚洲AV成人网| 久久精品国产一区二区电影| 久久综合久久性久99毛片| 欧美精品福利视频一区二区三区久久久精品| 久久久久国产精品| 久久精品国产亚洲7777| 久久99热这里只有精品国产| 久久综合狠狠综合久久 |