鱼C论坛

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

怎么设置全局变量

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

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

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

x
  1. // 从样例去分析,然后发现是二分
  2. //贪心使其x1尽量能多匹配前面的数
  3. #include <bits/stdc++.h>
  4. using namespace std;

  5. int n;
  6. bool check(int mid)  //区间覆盖
  7. {
  8.     int p;
  9.     for(int j=0;j<3;j++)
  10.     {
  11.         p=upper_bound(a.begin(),a.end(),a[p]+mid*2)-a.begin();
  12.         if(p==n)return true;

  13.     }
  14.     return false;
  15. }
  16. void solve()
  17. {
  18.      cin>>n;
  19.      vector<int>a(n);
  20.     for(int i=0;i<n;i++)
  21.     {
  22.         cin>>a[i];
  23.     }
  24.     sort(a.begin(),a.end());
  25.     int l=1,r=1e9;
  26.     while(l<r)
  27.     {
  28.         int mid=l+r>>1;
  29.         if(check(mid))r=mid-1;
  30.         else l=mid;
  31.     }
  32.     cout<<r<<endl;
  33. }
  34. int main()
  35. {
  36.     int t;
  37.     cin>>t;
  38.     while(t--)
  39.     {
  40.         solve();
  41.     }

  42. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-15 20:03:00 | 显示全部楼层
你需要设置全局变量a,但是在你的代码中a是一个局部变量。你需要将a声明为全局变量,可以将它放在函数外部,例如在int n;的下面。

  1. #include <bits/stdc++.h>
  2. using namespace std;

  3. int n;
  4. vector<int> a;  // 将a声明为全局变量

  5. bool check(int mid)
  6. {
  7.     int p;
  8.     for(int j=0; j<3; j++)
  9.     {
  10.         p = upper_bound(a.begin(), a.end(), a[p]+mid*2) - a.begin();
  11.         if(p == n) return true;
  12.     }
  13.     return false;
  14. }

  15. void solve()
  16. {
  17.     cin >> n;
  18.     a.resize(n);  // 调整a的大小
  19.     for(int i=0; i<n; i++)
  20.     {
  21.         cin >> a[ i];
  22.     }
  23.     sort(a.begin(), a.end());
  24.     int l=1, r=1e9;
  25.     while(l<r)
  26.     {
  27.         int mid = l+r >> 1;
  28.         if(check(mid)) r = mid-1;
  29.         else l = mid;
  30.     }
  31.     cout << r << endl;
  32. }

  33. int main()
  34. {
  35.     int t;
  36.     cin >> t;
  37.     while(t--)
  38.     {
  39.         solve();
  40.     }
  41. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-9 07:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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