#include<stdio.h>
int main()
{
double a=0,b=0,c=0,sumk=0,sums=0,sum=0;
int n=0,m=0;
scanf("%d %d",&n,&m);
double k[n];
double s[n];
double ave[n];
for(int i=0;i<n;i++)
{
scanf("%lf",&k[i]);
sumk=sumk+k[i];
}
for(int i=0;i<n;i++)
{
scanf("%lf",&s[i]);
sums=sums+s[i];
}
for(int i=0;i<n;i++)
{
ave[i]=s[i]/k[i];
}
for(int i=0;i<n-1;i++)
{
for(int j=i+1;j<n;j++)
{
if(ave[i]<ave[j])
{
a=ave[i];
ave[i]=ave[j];
ave[j]=a;
b=k[i];
k[i]=k[j];
k[j]=b;
c=s[i];
s[i]=s[j];
s[j]=c;
}
}
}
if(sumk<=m)
{
printf("%.2lf",sums);
}
else
{
for(int i=0;i<n;i++)
{
if((m-k[i])>=0)
{
sum=sum+s[i];
m=m-k[i];
}
else
{
sum=sum+m*ave[i];
break;
}
}
printf("%.2lf",sum);
}
return 0;
}
主要在于判断库存与需求的联系。
相关文章
- 10-16PAT乙级1010 一元多项式求导
- 10-16PAT乙级 1011 A+B 和 C
- 10-16PAT 乙级真题 1011.个位数统计
- 10-16PAT乙级1011题解
- 10-16PAT 乙级 (Basic Level) Practice (中文)1058
- 10-16PAT乙级1028
- 10-16PAT乙级1026
- 10-16PAT乙级1023
- 10-16PAT 1023 组个最小数 C语言实现
- 10-16[PAT-乙级]-1023.组个最小数