• <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 閱讀(157) 評論(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 
            精品久久久久久国产免费了| 亚洲午夜久久影院| 亚洲精品成人网久久久久久| 久久无码精品一区二区三区| 国内精品久久久久影院老司| 久久久久亚洲Av无码专| 精品久久久久国产免费| 偷窥少妇久久久久久久久| 久久久久久国产精品无码超碰| 亚洲国产成人久久综合一| 香蕉久久永久视频| 久久中文字幕一区二区| 天天爽天天狠久久久综合麻豆| 精品国产91久久久久久久| 2021国产精品久久精品| 91精品国产9l久久久久| 777午夜精品久久av蜜臀| 日韩亚洲国产综合久久久| 久久久久久久久久久久中文字幕| 欧美伊人久久大香线蕉综合69| 久久精品人成免费| 99久久国产精品免费一区二区| 国产午夜精品久久久久九九| 久久国产色AV免费看| 综合人妻久久一区二区精品| 色综合久久久久综合99| 久久久久国色AV免费看图片| 色天使久久综合网天天| 久久99精品国产| 久久综合狠狠色综合伊人| …久久精品99久久香蕉国产| 香蕉久久av一区二区三区| 久久久精品人妻一区二区三区蜜桃| 久久人做人爽一区二区三区| 久久伊人影视| 国产69精品久久久久观看软件| 亚洲国产日韩综合久久精品| 久久人妻无码中文字幕| 亚洲色欲久久久久综合网| 亚洲国产成人精品女人久久久| 亚洲精品成人久久久|