贪心算法之背包问题

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

const int M=1000005;
struct three{
    double w;//每个宝物的重量
    double v;//每个宝物的价值
    double p;;//性价比
}s[M];

bool cmp(three a, three b)
{
    return a.p>b.p;//根据宝物的单位价值从大到小排序
}

int main()
{
    int n;//n 表示有n个宝物
    double m;//m 表示毛驴的承载能力
    cin>>n>>m;
    for(int i=0;i<n;i++)
    {
        cin>>s[i].w>>s[i].v;
        s[i].p=s[i].w/s[i].w;//每个宝物单位价值
    }
    sort(s,s+n,cmp);
    double sum =0.0;// sum 表示贪心记录运走宝物的价值之和
    for(int i=0;i<n;i++)//按照排好的顺序贪心
    {
        if(m>s[i].w)//如果宝物的重量小于毛驴剩下的承载能力
        {
            m-=s[i].w;
            sum+=s[i].v;
        }
        else{//如果宝物的重量大于毛驴剩下的承载能力
            sum+=m*s[i].p;
            break;
        }
    }
    cout<<sum<<endl;//输出装入宝物的最大价值
    return 0;
}

 

posted @ 2019-07-05 21:16  xjyxp01  阅读(178)  评论(0编辑  收藏  举报