• <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 閱讀(154) 評論(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 
            国产成人精品久久二区二区| 97热久久免费频精品99| 亚洲国产成人精品无码久久久久久综合 | 久久亚洲高清观看| 久久免费视频一区| 色综合久久无码五十路人妻| 国产激情久久久久影院老熟女免费 | 亚洲国产精品久久久久网站| 无码国内精品久久人妻麻豆按摩| A级毛片无码久久精品免费| 99久久国产综合精品成人影院| 亚洲七七久久精品中文国产| 久久久久久久99精品免费观看| 天堂无码久久综合东京热| 99久久精品国产麻豆| 精品久久久久久久久免费影院| 欧美激情精品久久久久| 免费精品国产日韩热久久| 9999国产精品欧美久久久久久| 亚洲午夜久久久影院伊人| 亚洲国产日韩欧美综合久久| 久久精品一区二区三区不卡| 伊人久久大香线蕉av不变影院| 久久久受www免费人成| 91久久精品国产91性色也| 久久久久亚洲精品无码蜜桃| 欧美一区二区久久精品| 欧美久久天天综合香蕉伊| 成人亚洲欧美久久久久| 久久九九亚洲精品| 精品久久8x国产免费观看| 亚洲午夜久久久久久噜噜噜| 国产精品久久婷婷六月丁香| 久久久久九九精品影院| 99久久国产主播综合精品| 99久久免费只有精品国产| 久久精品草草草| 久久99国产精品久久久| 中文字幕成人精品久久不卡| 久久亚洲精品中文字幕三区| 国内精品久久久久影院免费|