社区讨论
c++求助
P2240【深基12.例1】部分背包问题参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @lo2x8wsk
- 此快照首次捕获于
- 2023/10/23 21:16 2 年前
- 此快照最后确认于
- 2023/10/23 21:16 2 年前
CPP
#include<iostream>
#include<algorithm>
using namespace std;
typedef struct{
double w,v;
double z;
}s;
int cmp(s a,s b){
return a.z>b.z;
}
int main(){
s a[10000]={0};
int n,t,i;
double sum=0.00;
cin>>n>>t;
for(i=1;i<=n;i++){
cin>>a[i].w>>a[i].v;
a[i].z=a[i].v/a[i].w;
}
sort (a,a+n,cmp);
for(i=1;i<=n;i++){
if(a[i].w<=t){
sum+=a[i].v;
t-=a[i].w;
}
if(a[i].w>t){
sum+=t*a[i].z;
break;
}
}
cout<<sum;
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...