• <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 - 12,  comments - 16,  trackbacks - 0
              
            Shopping Offers
            IOI'95

            In a certain shop, each kind of product has an integer price. For example, the price of a flower is 2 zorkmids (z) and the price of a vase is 5z. In order to attract more customers, the shop introduces some special offers.

            A special offer consists of one or more product items together for a reduced price, also an integer. Examples:

            • three flowers for 5z instead of 6z, or
            • two vases together with one flower for 10z instead of 12z.

            Write a program that calculates the price a customer has to pay for a purchase, making optimal use of the special offers to make the price as low as possible. You are not allowed to add items, even if that would lower the price.

            For the prices and offers given above, the (lowest) price for three flowers and two vases is 14z: two vases and one flower for the reduced price of 10z and two flowers for the regular price of 4z.

            PROGRAM NAME: shopping

            INPUT FORMAT

            The input file has a set of offers followed by a purchase.
            Line 1: s, the number of special offers, (0 <= s <= 99).
            Line 2..s+1: Each line describes an offer using several integers. The first integer is n (1 <= n <= 5), the number of products that are offered. The subsequent n pairs of integers c and k indicate that k items (1 <= k <= 5) with product code c (1 <= c <= 999) are part of the offer. The last number p on the line stands for the reduced price (1 <= p <= 9999). The reduced price of an offer is less than the sum of the regular prices.
            Line s+2: The first line contains the number b (0 <= b <= 5) of different kinds of products to be purchased.
            Line s+3..s+b+2: Each of the subsequent b lines contains three values: c, k, and p. The value c is the (unique) product code (1 <= c <= 999). The value k indicates how many items of this product are to be purchased (1 <= k <= 5). The value p is the regular price per item (1 <= p <= 999). At most 5*5=25 items can be in the basket.

            SAMPLE INPUT (file shopping.in)

            2
            1 7 3 5
            2 7 1 8 2 10
            2
            7 3 2
            8 2 5
            

            OUTPUT FORMAT

            A single line with one integer: the lowest possible price to be paid for the purchases.

            SAMPLE OUTPUT (file shopping.out)

            14

            解答:
            0 <= b <= 5,1 <= k <= 5,可用5*5*5*5*5的DP 每種買0~5個,可以用6進制表示,然后5維DP~OK!

            狀態設置:F[a1][a2][a3][a4][a5]為買a1件物品1,a2件物品2,a3件物品3,a4件物品4,a5件物品5時,所需的最少價格

            邊界條件:F[0][0][0][0][0]=0;

            狀態轉移方程:
            F[a1][a2][a3][a4][a5]=min{F[ a1-P[i][1] ][ a2-P[i][2] ][ a3-P[i][3] ][ a4-P[i][4] ][ a5-P[i][5] ]+P[i][0]}
            其中i=1..s+b; 且 ak-p[i][k]>=0

            /*
            ID: kuramaw1
            PROG: shopping
            LANG: C++
            */

            #include 
            <fstream>
            #include 
            <cstring>


            using std::ifstream;
            using std::ofstream;
            using std::endl;

            #define  MAX_T(a,b) ((a)>(b)?(a):(b))

            #define  MAX 5
            #define  MAX_S 100

            int f[MAX+1][MAX+1][MAX+1][MAX+1][MAX+1];//min price

            short s,b;
            short s_p[MAX_S],component[MAX_S][MAX],p_num[MAX],p[MAX],p_t(0),order[MAX];

            inline 
            short product_code_to_order(short code)
            {
                
            for(int i=0;i<p_t;i++)
                 
            if(p_num[i]==code)
                     
            return i;
                p_num[p_t
            ++]=code;
                
            return (p_t-1);

            }

            int main()
            {
                ifstream 
            in("shopping.in");
                
            in>>s;
                memset(component,
            0,sizeof(component));
                
            for(int i=0;i<s;i++)
                {
                    
            short n;
                    
            in>>n;
                    
            for(int j=0;j<n;j++)
                    {
                        
            short c,k;
                        
            in>>c>>k;
                        component[i][product_code_to_order(c)]
            =k;
                    }
                    
            in>>s_p[i];
                        
                }

                memset(order,
            0,sizeof(order));
                memset(p,
            0,sizeof(p));
                
            in>>b;
                
            for(int i=0;i<b;i++)
                {
                    
            short c,k,p1;
                    
            in>>c>>k>>p1;
                    
            short n=product_code_to_order(c);
                    order[n]
            =k;
                    p[n]
            =p1;
                }
                
            in.close();

                
            //do dp
                short ii[MAX];
            #define loop(i)  for(ii[i]=0;ii[i]<=order[i];ii[i]++)
            #define  F(a) f[a[0]][a[1]][a[2]][a[3]][a[4]]
                
                loop(
            0) loop(1) loop(2) loop(3) loop(4)
                {

                    F(ii)
            =ii[0]*p[0]+ii[1]*p[1]+ii[2]*p[2]+ii[3]*p[3]+ii[4]*p[4];
                    
            for(short j=0;j<s;j++)
                    {
                        
            short t[MAX];
                        
            for(short k=0;k<5;k++)
                            t[k]
            =MAX_T(0,ii[k]-component[j][k]);
                        
            if(F(t)+s_p[j]<F(ii))
                            F(ii)
            =F(t)+s_p[j];

                    }
                }

                
            //out
                ofstream out("shopping.out");
                
            out<<F(order)<<endl;
                
            out.close();


            }


            posted on 2009-08-13 11:46 kuramawzw 閱讀(496) 評論(0)  編輯 收藏 引用 所屬分類: USACO
            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            常用鏈接

            留言簿(5)

            隨筆分類

            隨筆檔案

            文章檔案

            Algorithm

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久伊人亚洲AV无码网站| 欧美伊人久久大香线蕉综合69 | 久久99精品国产99久久| 91久久九九无码成人网站| 亚洲国产日韩欧美综合久久| 午夜久久久久久禁播电影| 91久久精品视频| 日韩精品久久无码人妻中文字幕| 99久久婷婷免费国产综合精品| 久久99精品国产99久久| 97精品依人久久久大香线蕉97| 久久777国产线看观看精品| 久久婷婷国产剧情内射白浆 | 久久亚洲欧美国产精品| 久久精品成人影院| 国产精品久久永久免费| 无码人妻久久久一区二区三区 | 久久综合给久久狠狠97色| 久久综合九色综合欧美就去吻| 久久不见久久见免费视频7| 久久综合亚洲色HEZYO社区| 国产女人aaa级久久久级| 国产情侣久久久久aⅴ免费| 久久精品国产亚洲AV影院| 久久久免费观成人影院| 久久亚洲国产中v天仙www| 国产成人久久精品激情| 国内精品久久久久久久久电影网| 久久se精品一区二区影院 | 欧美久久亚洲精品| 久久久久国产精品嫩草影院| 中文字幕成人精品久久不卡| 97久久精品国产精品青草| 97精品久久天干天天天按摩| 亚洲精品乱码久久久久久中文字幕| 久久天天躁狠狠躁夜夜avapp | 国产 亚洲 欧美 另类 久久| 久久青青草原精品影院| 亚洲嫩草影院久久精品| 久久久久99精品成人片牛牛影视| 国产精品熟女福利久久AV|