概述
有m元钱,n种物品;每种物品有j磅,总价值f元,可以使用0到f的任意价格购买相应磅的物品。要求输出用m元最多能买到多少磅物品?
代码如下:
#include<stdio.h>
#include<algorithm>using namespace std;
struct goods{
double j;
double f;
double s;
bool operator<(const goods &A) const{
return s>A.s;
}
}buf[1000];
int main(){
double m;
int n;
while(scanf("%lf%d",&m,&n)!=EOF){
if(m==-1&&n==-1) break;
for(int i=0;i<n;i++){
scanf("%lf%lf",&buf[i].j,&buf[i].f);
buf[i].s=buf[i].j/buf[i].f;
}
sort(buf,buf+1);
int idx=0;
double ans=0;
while(m>0&&idx<n){
if(m>buf[idx].f){
ans+=buf[idx].j;
m-=buf[idx].f;
}
else{
ans+=buf[idx].j*m/buf[idx].f;
m=0;
}
idx++;
}
printf("%.3lfn",ans);
}
return 0;
}
最后
以上就是平常悟空为你收集整理的贪心算法(一)的全部内容,希望文章能够帮你解决贪心算法(一)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复