在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
第十题 付账问题
题解 这是一道想出来就ac,想不出来就0分的贪心题,贪心策略如下: 先求一个不变的平均费用avg = S/n,如果有人付不起avg,他们要把他们的钱全付完,不够的需要钱多于avg的人付,但是这些付不起avg的人少付的钱会抬高>avg的人的付费平均值,或许又会有人付不起这个新的avg,就是nowavg,所以循环这个过程,直到没有人付不起被抬高的avg。这样的话那些都能付得起新的avg的有钱人付的钱均相等,都是新的avg。
代码 #include<iostream> #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> #define ll long long #define num ch-'0' #define ld long double #define rep(i,a,b) for(register int i=(a);i<=(b);++i) using namespace std; const int N=500010; ll cnt,n,m,a[N]; ld b[N],ans=0,avg,tot,nowavg; inline void get(ll &res) { char ch;bool flag=0; while(!isdigit(ch=getchar())) (ch=='-')&&(flag=true); for(res=num;isdigit(ch=getchar());res=res*10+num); (flag)&&(res=-res); } int main() { get(n),get(m); rep(i,1,n) get(a[i]); sort(a+1,a+n+1); nowavg=avg=1.0*m/n; tot=0; rep(i,1,n) { if(a[i]<nowavg) { ans+=(a[i]-avg)*(a[i]-avg); tot+=a[i]; } else { nowavg=(m-tot)/(n-i+1); if(a[i]>=nowavg) { ans+=(nowavg-avg)*(nowavg-avg)*(n-i+1); break; } --i; } } ans/=(ld)n; ans=sqrt(ans); printf("%.4Lf",(ld)ans); return 0; } 谢谢大家! |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论