惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

K
Kaspersky official blog
Martin Fowler
Martin Fowler
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
V
Visual Studio Blog
博客园_首页
Engineering at Meta
Engineering at Meta
The Cloudflare Blog
MongoDB | Blog
MongoDB | Blog
Blog — PlanetScale
Blog — PlanetScale
T
The Blog of Author Tim Ferriss
雷峰网
雷峰网
D
Docker
博客园 - 司徒正美
S
SegmentFault 最新的问题
M
MIT News - Artificial intelligence
博客园 - 叶小钗
博客园 - 三生石上(FineUI控件)
U
Unit 42
J
Java Code Geeks
A
About on SuperTechFans
N
Netflix TechBlog - Medium
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Security Affairs
I
Intezer
Cisco Talos Blog
Cisco Talos Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
B
Blog RSS Feed
P
Privacy & Cybersecurity Law Blog
T
Tenable Blog
T
Threatpost
H
Hacker News: Front Page
G
Google Developers Blog
博客园 - 【当耐特】
Hugging Face - Blog
Hugging Face - Blog
Apple Machine Learning Research
Apple Machine Learning Research
L
Lohrmann on Cybersecurity
大猫的无限游戏
大猫的无限游戏
Google DeepMind News
Google DeepMind News
A
Arctic Wolf
S
Secure Thoughts
GbyAI
GbyAI
NISL@THU
NISL@THU
S
Security @ Cisco Blogs
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
Webroot Blog
Webroot Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
O
OpenAI News
Spread Privacy
Spread Privacy
Application and Cybersecurity Blog
Application and Cybersecurity Blog

OneCoder

【GESP】C++一级真题 luogu-B4551 [GESP202606 一级] 去旅行 【GESP】C++一级真题 luogu-B4552 [GESP202606 一级] 交税 【NOIP】2000真题解析 luogu-P1023 税收与补贴问题(适合GESP四、五级以上练习) 【NOIP】2000真题解析 luogu-P1022 计算器的改良(适合GESP四、五级以上练习) 【NOIP】2001真题解析 luogu-P1029 最大公约数和最小公倍数问题 【CSP】CSP-X 2018真题 11的倍数 luogu-B4075 (适合GESP三级及以上考生练习) 【CSP】CSP-X 2018真题 统计成绩 luogu-B4074 (适合GESP二级及以上考生练习) 【CSP】CSP-X 2018真题 快递费用 luogu-B4073 (适合GESP二级及以上考生练习) 【CSP】CSP-X 2018真题 小明的照片 luogu-B4072 (适合GESP一级及以上考生练习) 【GESP】C++四级练习 luogu-P1138 第 k 小整数 【NOIP】2008真题解析 luogu-P1125 笨小猴 【信奥业余科普】C++ 的奇妙之旅 29:别让 TLE 和 MLE 偷走你的分——复杂度估算与数据范围速查 【信奥业余科普】C++ 的奇妙之旅 28:规范比赛代码的钥匙——文件操作与输入输出重定向(freopen) 【CSP】CSP-J 2023真题 公路 luogu-P9749 (适合GESP四级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 27:高效处理数据的利器——常用算法库(algorithm) 【CSP】CSP-J 2022真题 解密 luogu-P8814 (适合GESP四级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 26:高效的键值对——映射(map)与多重映射(multimap) 【CSP】CSP-J 2022真题 乘方 luogu-P8813 (适合GESP二级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 25:自动排序的利器——集合(set)与多重集合(multiset) 【CSP】CSP-J 2019真题 纪念品 luogu-P5662 (适合GESP六级及以上考生练习) 【信奥业余科普】C++ 的奇妙之旅 24:拆解 deque——分段连续的双端队列 【信奥业余科普】C++ 的奇妙之旅 23:主动限制的艺术——栈(stack)与队列(queue)
【GESP】C++二级真题 luogu-B4553 [GESP202606 二级] 完全平方数计数
OneCoder · 2026-06-30 · via OneCoder

GESP C++二级,2026年6月真题,循环和数学运算,难度⭐,洛谷难度入门

luogu-B4553 [GESP202606 二级] 完全平方数计数

题目要求

题目描述

小杨同学正在研究完全平方数。

平方: 一个数的平方等于这个数乘以这个数本身。

完全平方数: 指可以恰好表示为某个正整数的平方的数。

例如,$9$ 是完全平方数,因为 $9 = 3^2 = 3 \times 3$;但 $27$ 不是,因为 $27$ 不能表示为任何正整数的平方。

给定两个正整数 $l$ 和 $r$(保证 $l \le r$),小杨同学想知道 $l$ 到 $r$ 之间的所有正整数中(包含 $l$ 和 $r$),有多少个数是完全平方数。

输入格式

输入两行,第一行为一个正整数 $l$,第二行为一个正整数 $r$。

输出格式

输出一个非负整数,表示 $l$ 到 $r$ 中,有多少个正整数是完全平方数。如果 $l$ 到 $r$ 中没有完全平方数,则输出 $0$。

输入输出样例 #1

输入 #1

输出 #1

说明/提示

样例解释 1

在 $1$ 到 $21$ 中,有以下 $4$ 个整数是完全平方数: $1, 4, 9, 16$。

数据范围

$1 \le l \le r \le 2000$。


题目分析

解题思路

本题的解题思路如下:

  1. 问题本质:
    • 输入两个正整数 $l,r$,表示一个整数范围
    • 需要计算范围 $[l, r]$ 内有多少个完全平方数
  2. 解题关键 — 判断完全平方数:
    • 方法一(逐个判断):遍历 $l$ 到 $r$ 的每个数 $i$,对 $i$ 开平方后取整,判断平方后是否等于 $i$
    • 方法二(直接计数):利用数学性质,$[1, n]$ 中的完全平方数个数等于 $\lfloor\sqrt{n}\rfloor$,因此 $[l, r]$ 中的完全平方数个数等于 $\lfloor\sqrt{r}\rfloor - \lfloor\sqrt{l-1}\rfloor$
  3. 复杂度分析:
    • 方法一:时间复杂度 $O(r - l + 1)$,遍历范围内每个数
    • 方法二:时间复杂度 $O(1)$,仅需两次开平方运算
    • 空间复杂度:$O(1)$

示例代码

方法一、逐个判断

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <cmath>

int main() {
    // 定义输入的范围边界
    int l, r;
    // 从标准输入读取 l 和 r
    std::cin >> l >> r;
    // 计数器,记录完全平方数的个数
    int count = 0;
    // 遍历范围内的每个数
    for (int i = l; i <= r; i++) {
        // 对 i 开平方并取整
        int s = (int)std::sqrt(i);
        // 如果 s 的平方等于 i,则 i 是完全平方数
        if (s * s == i) {
            count++;
        }
    }
    // 输出完全平方数的个数
    std::cout << count << std::endl;
    return 0;
}

方法二、数学公式直接计算

利用 $[1, n]$ 中完全平方数的个数等于 $\lfloor\sqrt{n}\rfloor$ 这一性质,直接计算 $\lfloor\sqrt{r}\rfloor - \lfloor\sqrt{l-1}\rfloor$ 即可。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
#include <cmath>

int main() {
    // 定义输入的范围边界
    int l, r;
    // 从标准输入读取 l 和 r
    std::cin >> l >> r;
    // [1, r] 中完全平方数的个数为 floor(sqrt(r))
    // [1, l-1] 中完全平方数的个数为 floor(sqrt(l-1))
    // 两者相减即为 [l, r] 中完全平方数的个数
    int count = (int)std::sqrt(r) - (int)std::sqrt(l - 1);
    // 输出结果
    std::cout << count << std::endl;
    return 0;
}


所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code

GESP 学习专题站:GESP WIKI

"luogu-"系列题目可在洛谷题库进行在线评测。

"bcqm-"系列题目可在编程启蒙题库进行在线评测。

欢迎加入Java、C++、Python技术交流QQ群(982860385),大佬免费带队,有问必答

欢迎加入C++ GESP/CSP认证学习QQ频道,考试资源总结汇总

欢迎加入C++ GESP/CSP学习交流QQ群(688906745),考试认证学员交流,互帮互助

GESP/CSP 认证学习微信公众号

GESP/CSP 认证学习微信公众号