我是靠谱客的博主 平常悟空,这篇文章主要介绍贪心算法(一),现在分享给大家,希望可以做个参考。

有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;

最后

以上就是平常悟空最近收集整理的关于贪心算法(一)的全部内容,更多相关贪心算法(一)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(78)

评论列表共有 0 条评论

立即
投稿
返回
顶部