找回密码
 立即注册
首页 业界区 科技 题解:AT_abc389_d [ABC389D] Squares in Circle

题解:AT_abc389_d [ABC389D] Squares in Circle

胰芰 2025-6-9 16:40:34
假定原点为圆心。
我们只考虑点在第一象限的情况,剩下的情况同理。
因为圆心是原点,所以在圆内的点的横坐标一定在 \(r\) 之内。
枚举点的横坐标 \(x + \frac{1}{2}\),二分最大的 \(y + \frac{1}{2}\),使得点 \((x + \frac{1}{2}, y + \frac{1}{2})\) 到原点的距离 \(\le r\) (因为我们令圆心为原点,所以所有的点都应平移一段)。
此时所有横坐标为 \(x + \frac{1}{2}\) 的在圆内的点分别是:

\[(x + \frac{1}{2}, \frac{1}{2}),(x + \frac{1}{2}, 1 + \frac{1}{2}),(x + \frac{1}{2}, 2 + \frac{1}{2}),\dots,(x + \frac{1}{2}, y + \frac{1}{2})\]
一共是 \(y + 1\) 个。
将枚举的所有 \(x\) 算出来的答案加起来记为 \(t\)。
因为我们只考虑了第一象限,所以答案是 \(4 \times t + 1\)(需要考虑原点的情况,所以要 $ + 1$)。
  1. #include <bits/stdc++.h>
  2. #define int long long
  3. #define pii pair<int, int>
  4. #define FRE(x) freopen(x ".in", "r", stdin), freopen(x ".out", "w", stdout)
  5. #define ALL(x) x.begin(), x.end()
  6. using namespace std;
  7. inline void cmax(int& x, int c) {
  8.     x = max(x, c);
  9. }
  10. inline void cmin(int& x, int c) {
  11.     x = min(x, c);
  12. }
  13. int _test_ = 1;
  14. int n, ans;
  15. double dis(double x, double y) {
  16.     return (double)sqrt((double)((double)((double)x + 0.5) * (double)((double)x + 0.5) + (double)((double)y + 0.5) * (double)((double)y + 0.5)));
  17. }
  18. void init() {}
  19. void clear() {}
  20. void solve() {
  21.     cin >> n;
  22.     for (int i = 1; i < n; i++) {
  23.         int l = 0, r = n, t = 0;
  24.         while (l <= r) {
  25.             int mid = (l + r) >> 1;
  26.             if (dis(i, mid) <= (double)n) {
  27.                 t = mid;
  28.                 l = mid + 1;
  29.             } else
  30.                 r = mid - 1;
  31.         }
  32.         ans += t + 1;
  33.     }
  34.     cout << ans * 4 + 1;
  35. }
  36. signed main() {
  37.     ios::sync_with_stdio(0);
  38.     cin.tie(0), cout.tie(0);
  39.     // cin >> _test_;
  40.     init();
  41.     while (_test_--) {
  42.         clear();
  43.         solve();
  44.     }
  45.     return 0;
  46. }
复制代码
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册