鱼C论坛

 找回密码
 立即注册
查看: 1499|回复: 1

修改代码

[复制链接]
发表于 2023-11-14 22:02:54 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. const int N=2e5+10;
  4. int a[N];
  5. int n;
  6. long long c;
  7. void putin()
  8. {
  9.     cin>>n>>c;
  10.     for(int i=0;i<n;i++)
  11.     {
  12.         cin>>a[i];
  13.     }
  14. }
  15. bool check(int k)
  16. {
  17.     long long sum=0;
  18.     for(int i=0;i<n;i++)
  19.     {
  20.         sum+=pow((a[i]+2*k),2);
  21.         
  22.     }
  23.     return sum>=c;

  24. }
  25. void search()
  26. {
  27.     long long l=1,r=ceil(sqrt(c/(n*4)));
  28.     while (l<r)
  29.     {
  30.         long long mid=l+r+1>>2;
  31.         if(check(mid)) l=mid;
  32.         else r=mid-1;
  33.     }
  34.     cout<<r<<endl;
  35.    
  36. }
  37. int main()
  38. {
  39.     int t;
  40.     cin>>t;
  41.     while(t--)
  42.     {
  43.     putin();
  44.     search();
  45.     }

  46. }
复制代码

为什么没有输出呢
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-14 22:03:00 | 显示全部楼层
你的代码中存在一个错误。在 search 函数中,计算 mid 的方式不正确,应该是 long long mid=(l+r+1)/2; 而不是 long long mid=l+r+1>>2; 。将这一行修改为 long long mid=(l+r+1)/2; 即可解决问题。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 06:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表