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

            學習心得(code)

            superlong@CoreCoder

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              74 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

            公告

            文字可能放在http://blog.csdn.net/superlong100,此處存放代碼

            常用鏈接

            留言簿(4)

            我參與的團隊

            搜索

            •  

            最新隨筆

            最新評論

            • 1.?re: Poj 1279
            • 對于一個凹多邊形用叉積計算面積 后能根據結果的正負來判斷給的點集的時針方向?
            • --bsshanghai
            • 2.?re: Poj 3691
            • 你寫的這個get_fail() 好像并是真正的get_fail,也是說fail指向的串并不是當前結點的子串。為什么要這樣弄呢?
            • --acmer1183
            • 3.?re: HDU2295[未登錄]
            • 這個是IDA* 也就是迭代加深@ylfdrib
            • --superlong
            • 4.?re: HDU2295
            • 評論內容較長,點擊標題查看
            • --ylfdrib
            • 5.?re: HOJ 11482
            • 呵呵..把代碼發在這里很不錯..以后我也試試...百度的編輯器太爛了....
            • --csuft1

            閱讀排行榜

            評論排行榜

            Mixing Milk

            Since milk packaging is such a low margin business, it is important to keep the price of the raw product (milk) as low as possible. Help Merry Milk Makers get the milk they need in the cheapest possible manner.

            The Merry Milk Makers company has several farmers from which they may buy milk, and each one has a (potentially) different price at which they sell to the milk packing plant. Moreover, as a cow can only produce so much milk a day, the farmers only have so much milk to sell per day. Each day, Merry Milk Makers can purchase an integral amount of milk from each farmer, less than or equal to the farmer's limit.

            Given the Merry Milk Makers' daily requirement of milk, along with the cost per gallon and amount of available milk for each farmer, calculate the minimum amount of money that it takes to fulfill the Merry Milk Makers' requirements.

            Note: The total milk produced per day by the farmers will be sufficient to meet the demands of the Merry Milk Makers.

            PROGRAM NAME: milk

            INPUT FORMAT

            Line 1: Two integers, N and M.
            The first value, N, (0 <= N <= 2,000,000) is the amount of milk that Merry Milk Makers' want per day. The second, M, (0 <= M <= 5,000) is the number of farmers that they may buy from.
            Lines 2 through M+1: The next M lines each contain two integers, Pi and Ai.
            Pi (0 <= Pi <= 1,000) is price in cents that farmer i charges.
            Ai (0 <= Ai <= 2,000,000) is the amount of milk that farmer i can sell to Merry Milk Makers per day.

            SAMPLE INPUT (file milk.in)

            100 5
            5 20
            9 40
            3 10
            8 80
            6 30

            OUTPUT FORMAT

            A single line with a single integer that is the minimum price that Merry Milk Makers can get their milk at for one day.

            SAMPLE OUTPUT (file milk.out)

            630

            一個不完全背包,簡單貪心,對fammer信息按price從小到大排序,
            然后裝進背包求minnum price就好了。
            代碼:
            /*
            ID: superlo1
            LANG: C++
            TASK: milk
            */

            #include 
            <iostream>
            #include 
            <algorithm>
            using namespace std;

            struct node
            {
                
            int p, a;
            }fam[
            5001];

            bool cmp(node a,node b)
            return a.p < b.p; }

            int n, m;

            int main()
            {
                freopen(
            "milk.in","r",stdin);
                freopen(
            "milk.out","w",stdout);
                scanf(
            "%d %d"&n, &m);
                
            int i;
                
            for(i = 0; i < m; i ++)
                    scanf(
            "%d %d"&fam[i].p, &fam[i].a);
                sort( fam, fam 
            + m, cmp);
                
            int ans = 0;
                i 
            = 0;
                
            while(n)
                {
                    
            if( n > fam[i].a)
                    {
                        n 
            -= fam[i].a;
                        ans 
            += fam[i].p * fam[i].a;
                    }
                    
            else
                    {
                        ans 
            += n * fam[i].p;
                        n 
            = 0;
                    }
                    i 
            ++;
                }
                printf(
            "%d\n",ans);
                
            //while(1);
            }
            優化:以上為O(n*LOG(n)),因為price的范圍比較小,可以用一個
            hash[i]表示price為i的數量,然后線性的掃一遍就好了(類似桶排序吧)
            于是優化到O(n)。
            代碼:
            #include <fstream>
            #define MAXPRICE 1001
            using namespace std;

            int main() {
                ifstream fin (
            "milk.in");
                ofstream fout (
            "milk.out");
                unsigned 
            int i, needed, price, paid, farmers, amount, milk[MAXPRICE];
                paid 
            = 0;
                fin
            >>needed>>farmers;
                
            for(i = 0;i<farmers;i++){
                    fin
            >>price>>amount;
                    milk[price] 
            += amount;   
                } 
                
            for(i = 0; i<MAXPRICE && needed;i++){
                    
            if(needed> = milk[i]) {
                        needed 
            -= milk[i];
                        paid 
            += milk[i] * i;
                    } 
            else if(milk[i][0]>0) {
                        paid 
            += i*needed;
                        needed 
            = 0;     
                    }
                }
                fout 
            << paid << endl; 
                
            return 0;
            }


            posted on 2009-08-05 00:53 superlong 閱讀(372) 評論(0)  編輯 收藏 引用 所屬分類: USACO
            亚洲精品tv久久久久久久久久| 久久久精品国产sm调教网站| 97久久国产综合精品女不卡| 国产精品久久久久a影院| 99久久国产宗和精品1上映| 久久久久久久久无码精品亚洲日韩| 99久久久国产精品免费无卡顿| 中文国产成人精品久久亚洲精品AⅤ无码精品 | avtt天堂网久久精品| 99久久国产综合精品成人影院| 2021最新久久久视精品爱| 新狼窝色AV性久久久久久| 亚洲精品无码久久久| 久久久久人妻精品一区二区三区| 国产精自产拍久久久久久蜜| 亚洲AV成人无码久久精品老人 | 国内精品九九久久精品| 久久精品国产亚洲av水果派| 久久久久一本毛久久久| 久久精品亚洲一区二区三区浴池 | 一本一本久久A久久综合精品 | 香蕉久久夜色精品国产尤物| 天天久久狠狠色综合| 日韩久久久久久中文人妻| 狠狠精品久久久无码中文字幕| 超级碰久久免费公开视频| 久久久无码精品亚洲日韩按摩| 青青热久久国产久精品 | 99re这里只有精品热久久| 精品免费久久久久久久| 国产欧美久久久精品影院| 国产午夜福利精品久久| 国产精品久久久亚洲| 欧美伊人久久大香线蕉综合| 欧美久久一区二区三区| 欧美大战日韩91综合一区婷婷久久青草 | 精品久久综合1区2区3区激情| 久久香蕉国产线看观看乱码 | 亚洲Av无码国产情品久久| 99久久国产综合精品五月天喷水 | 无码人妻久久一区二区三区蜜桃|