我是靠谱客的博主 平常悟空,最近开发中收集的这篇文章主要介绍贪心算法(一),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

最后

以上就是平常悟空为你收集整理的贪心算法(一)的全部内容,希望文章能够帮你解决贪心算法(一)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

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

评论列表共有 0 条评论

立即
投稿
返回
顶部