• CodeForces 176A Trading Business 贪心


    Trading Business

    题目连接:

    http://codeforces.com/problemset/problem/176/A

    Description

    To get money for a new aeonic blaster, ranger Qwerty decided to engage in trade for a while. He wants to buy some number of items (or probably not to buy anything at all) on one of the planets, and then sell the bought items on another planet. Note that this operation is not repeated, that is, the buying and the selling are made only once. To carry out his plan, Qwerty is going to take a bank loan that covers all expenses and to return the loaned money at the end of the operation (the money is returned without the interest). At the same time, Querty wants to get as much profit as possible.

    The system has n planets in total. On each of them Qwerty can buy or sell items of m types (such as food, medicine, weapons, alcohol, and so on). For each planet i and each type of items j Qwerty knows the following:

    aij — the cost of buying an item;

    bij — the cost of selling an item;

    cij — the number of remaining items.

    It is not allowed to buy more than cij items of type j on planet i, but it is allowed to sell any number of items of any kind.

    Knowing that the hold of Qwerty's ship has room for no more than k items, determine the maximum profit which Qwerty can get.

    Input

    The first line contains three space-separated integers n, m and k (2 ≤ n ≤ 10, 1 ≤ m, k ≤ 100) — the number of planets, the number of question types and the capacity of Qwerty's ship hold, correspondingly.

    Then follow n blocks describing each planet.

    The first line of the i-th block has the planet's name as a string with length from 1 to 10 Latin letters. The first letter of the name is uppercase, the rest are lowercase. Then in the i-th block follow m lines, the j-th of them contains three integers aij, bij and cij (1 ≤ bij < aij ≤ 1000, 0 ≤ cij ≤ 100) — the numbers that describe money operations with the j-th item on the i-th planet. The numbers in the lines are separated by spaces.

    It is guaranteed that the names of all planets are different.

    Output

    Print a single number — the maximum profit Qwerty can get.

    Sample Input

    3 3 10

    Venus

    6 5 3

    7 6 5

    8 6 10

    Earth

    10 9 0

    8 6 4

    10 9 3

    Mars

    4 3 0

    8 4 12

    7 2 5

    Sample Output

    16

    Hint

    题意

    有n个星球,然后每个星球有m个商品,买需要ai元,卖需要bi元,只有ci个

    你需要在一个星球买最多k个商品,然后在一个星球卖出去

    问你最多赚多少钱

    题解:

    暴力枚举在哪个星球买,在哪个星球卖

    然后直接贪心的去选择k个商品就好了

    选择差价最大的k个商品

    代码

    #include<bits/stdc++.h>
    using namespace std;
    
    int a[20][200];
    int b[20][200];
    int c[20][200];
    int vis[200];
    int n,m,k;
    int solve(int x,int y)
    {
        memset(vis,0,sizeof(vis));
        int last = k;
        int ans = 0;
        while(last)
        {
            int flag = 0;
            int Max=0,Maxc=0;
            for(int i=1;i<=m;i++)
            {
                if(vis[i])continue;
                if(b[y][i]-a[x][i]>Max)
                {
                    Max=b[y][i]-a[x][i];
                    Maxc=i;
                    flag=1;
                }
            }
            if(!flag)break;
            int num = min(last,c[x][Maxc]);
            ans += num*Max;
            vis[Maxc]=1;
            last-=num;
        }
        return ans;
    }
    int main()
    {
    
        scanf("%d%d%d",&n,&m,&k);
        for(int i=1;i<=n;i++)
        {
            string s;
            cin>>s;
            for(int j=1;j<=m;j++)
                scanf("%d%d%d",&a[i][j],&b[i][j],&c[i][j]);
        }
        int ans = 0;
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
            {
                ans=max(ans,solve(i,j));
            }
        cout<<ans<<endl;
    }
  • 相关阅读:
    jetty服务器
    好久不用的正则表达式
    mysql技术调优资料整理
    .net互转java 转行必备
    docker学习资料整理(持续更新中..)
    tcpdump来抓取执行的sql语句
    DDoS deflate
    Linux网络相关查询脚本
    linux下无法删除文件的原因
    linux使用FIO测试磁盘的iops 【转载】
  • 原文地址:https://www.cnblogs.com/qscqesze/p/5146232.html
Copyright © 2020-2023  润新知