题解 | #A题 小L的三角尺#

小L的三角尺

https://ac.nowcoder.com/acm/contest/120566/A

本题就是要用最优的w分配,使得每一次减小y时,是最大效率,这样才能使得最终斜边和最短。为了知道最大的减小效率,其实就是每一个y[i]/x[i]的值。我们可以用优先队列加上pair函数的方式存储y[i]/x[i]和每一个i,之所以要存i,是为了以后方便提取每一个y[i]的精确值。 代码核心是这样的: using Real=long double;  void R() {     int n,w;     cin>>n>>w;     vector x(n),y(n);     for (int i=0;i<n;i++) cin>>x[i]>>y[i];      priority_queue<pair<Real,int>> q;     for (int i=0;i<n;i++)         q.push({Real(y[i])/x[i],i});     while (!q.empty()&&w)     {         auto [_,id]=q.top();         q.pop();         y[id]--,w--;         if (y[id]) q.push({Real(y[id])/x[id],id});     }      Real ans=0;     for (int i=0;i<n;i++)         ans+=sqrtl(x[i]*x[i]+y[i]*y[i]);     cout<<ans<<'\n';     return; }

全部评论

相关推荐

2025-12-29 20:37
已编辑
清华大学附属小学 Java
开始打牌offer啦:1.为什么要写这么多内容呀 2.什么叫做简历 3.什么样的内容可以写到简历上 4.项目可以包装,但是要有理有据呀,不能乱包装呀,比如 跨境能达到日均120万订单的在国内都是能叫的上名字的,而且这些工作也基本上不太会交给一个实习生去做 建议友友可以去网上或者找同学的简历看看,他们的简历是怎么写的,去找找上面的那四个问题的答案吧,然后要记住的是Java是服务于业务的,而不是服务于微服务或者技术的
最后再改一次简历
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务