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


            May the force be with you!
            posts - 52,  comments - 33,  trackbacks - 0


            題目描述:

            產(chǎn)品由n個部件組成(n= 100,每個部件有bp 兩個屬性值,每個部件有m種選擇(m=100),總產(chǎn)品的B=min{bi} P=Σ{pi}選擇各部件,使得最后產(chǎn)品的B/P值最大。

            解題思路:

            貪心。思路(來自Discuss)

            1,獲得一個最小和最大帶寬:

                最小帶寬是各個設(shè)備最小帶寬的最大值,

                最大帶寬是各個設(shè)備最大帶寬的最小值.

            2,從最小值遞增到最大值進(jìn)行尋找,

            計算各種設(shè)備價錢的最小值的和,然后計算出一個比值,

            如果比值比當(dāng)前比值大,更換當(dāng)前比值;

            3,重復(fù)2直到結(jié)束.

            /*

            for(i=0;i<總共的狀態(tài)數(shù);i++)

            {     for (j=0;j<總的部件數(shù);j++)

                   {     for(k=0;k<總的選擇;k++)

                                 求出滿足狀態(tài)i的,p值最小的部件;

                       total+=求出來的p

                 }

                 比較求出最大的B[i]/ total 的值;

            }

            */


             

             1/********************************************************************
             2Author: littlekid
             3Created Time: 2007-11-28
             4Problem Source: POJ1018
             5Description: 
             6********************************************************************/

             7# include <stdio.h>
             8
             9# define N 110
            10# define MAX 342289
            11
            12int b[ N ][ N ],p[ N ][ N ];
            13int m[ N ];
            14
            15int main()
            16{
            17    int n;
            18    int min_b, max_b;
            19    int sum_p, min_p;
            20    double max;
            21    int T; scanf( "%d"&T );
            22    while ( T -- )
            23    {
            24        max_b = 0; min_b = MAX;
            25        scanf("%d",&n);
            26        forint i = 0; i < n; ++ i)
            27        {
            28            scanf( "%d"&m[i] );
            29            forint j = 0; j < m[ i ]; ++ j )
            30            {
            31                scanf( "%d %d"&b[ i ][ j ], &p[ i ][ j ] );
            32                if ( max_b < b[ i ][ j ] ) max_b = b[ i ][ j ];
            33                if ( min_b > b[ i ][ j ] ) min_b = b[ i ][ j ];
            34            }

            35        }

            36        max = 0.00;
            37        forint i = min_b; i <= max_b; ++ i)
            38        {
            39            sum_p = 0;
            40            forint j = 0; j < n; ++ j)
            41            {
            42                min_p = MAX;
            43                forint k = 0; k < m[ j ]; ++ k )
            44                {
            45                    if( b[ j ][ k ] >= i && p[ j ][ k ] < min_p )
            46                    {
            47                        min_p = p[ j ][ k ];
            48                    }

            49                }

            50                sum_p += min_p;
            51            }

            52            if( (double)i / (double)sum_p > max ) 
            53            {
            54                max = (double)i / (double)sum_p;
            55            }

            56        }

            57        printf( "%.3lf\n", max );
            58    }

            59    return 0;
            60}

            61
            posted on 2007-12-01 23:10 R2 閱讀(1530) 評論(3)  編輯 收藏 引用 所屬分類: Problem Solving

            FeedBack:
            # re: POJ1018 Communication System[未登錄]
            2008-01-27 15:24 | yoyo
            在 判斷"求出滿足狀態(tài)i的,p值最小的部件" 這里有點(diǎn)疑惑

            當(dāng)B = i時 每組設(shè)備不一定是選p值最小的那個啊
            因?yàn)槟菢拥贸龅拇鸢覆灰欢˙=i ,只能說i肯定比最小值小 必須至少選一個bandwith為i的 這樣才符合最小的b是i

            所以我覺得需要加一個判斷是否有bandwidth為i的設(shè)備被選中,但是你這么做就已經(jīng)AC了,我想的是不是有哪里錯了?請麻煩指出 ^^

              回復(fù)  更多評論
              
            # re: POJ1018 Communication System
            2008-02-13 08:42 | R2@whuacm
            @yoyo
            你優(yōu)化的想法是對的,我當(dāng)時并沒有用到。
            NWERC 2007有個類題(WOJ1303)要用到優(yōu)化。  回復(fù)  更多評論
              
            # re: POJ1018 Communication System
            2010-03-30 21:40 | karying
            你的代碼好像有問題,你再看看  回復(fù)  更多評論
              
            你是第 free hit counter 位訪客




            <2008年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            留言簿(4)

            隨筆分類(54)

            隨筆檔案(52)

            文章檔案(1)

            ACM/ICPC

            技術(shù)綜合

            最新隨筆

            搜索

            •  

            積分與排名

            • 積分 - 63692
            • 排名 - 358

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久一区二区三区| 欧美国产成人久久精品| 99久久免费国产精精品| 久久久九九有精品国产| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 国产亚洲美女精品久久久2020| 狠狠色丁香久久婷婷综合_中| 人妻无码αv中文字幕久久琪琪布| 99久久99这里只有免费的精品| 久久精品国产只有精品66| 亚洲精品蜜桃久久久久久| 91精品国产高清久久久久久国产嫩草| 国产精品美女久久久免费| 热久久视久久精品18| 久久亚洲欧美日本精品| 色综合久久88色综合天天 | .精品久久久麻豆国产精品| 性高朝久久久久久久久久| 国产亚洲色婷婷久久99精品| 久久久久亚洲av成人无码电影 | 亚洲精品高清国产一久久| 一本久道久久综合狠狠躁AV| 久久精品国产久精国产| 色婷婷综合久久久久中文| 久久露脸国产精品| 99久久人人爽亚洲精品美女| 久久人爽人人爽人人片AV| 三级三级久久三级久久 | 亚洲精品无码久久久久| 香蕉aa三级久久毛片| 久久亚洲2019中文字幕| 久久综合综合久久97色| 77777亚洲午夜久久多喷| 久久精品天天中文字幕人妻| 亚洲国产精品无码久久SM| 久久人妻少妇嫩草AV蜜桃| 久久久久久久久久久精品尤物| 青青青青久久精品国产h久久精品五福影院1421 | 久久久久av无码免费网| 无码8090精品久久一区| 欧美久久综合九色综合|