社区讨论

80分求调

P2240【深基12.例1】部分背包问题参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mhjleo80
此快照首次捕获于
2025/11/04 04:28
4 个月前
此快照最后确认于
2025/11/04 04:28
4 个月前
查看原帖
为什么第一个测试点就WA了呢...
我这算法也没问题啊
(求调必关)
CPP
#include<bits/stdc++.h>
using namespace std;
int n,t;
struct jb{
	double zl,jz;
	double b;
}a[110];
double sum,cnt;
bool cmp(jb a,jb b){
	return a.b>b.b;
} 
int main(){
	cin>>n>>t;
	for(int i=1;i<=n;i++){
		cin>>a[i].zl>>a[i].jz;
		a[i].b=a[i].jz/a[i].zl;
	}
	sort(a+1,a+n+1,cmp);
	for(int i=1;i<=n;i++){
		if(sum>=t){
			cout<<fixed<<setprecision(2)<<cnt-((sum-t)*a[i-1].b*1.00);
			break;
		}else{
			sum+=a[i].zl;
			cnt+=a[i].jz;
		}
	}
	return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...