【GESP】C++二级真题 luogu-b4002, [GESP202406 二级] 平方之和
GESP二级真题,多层循环和分支练习,难度★✮☆☆☆。
luogu-B4002 [GESP202406 二级] 平方之和
题目要求
题目描述
小杨有 $n$ 个正整数 $a_1,a_2,\dots,a_n$,他想知道对于所有的 $i (1\le i\le n)$,是否存在两个正整数 $x$ 和 $y$ 满足 $x\times x+y \times y=a_i$。
输入格式
第一行包含一个正整数 $n$,代表正整数数量。 之后 $n$ 行,每行包含一个正整数,代表 $a_i$。
输出格式
对于每个正整数 $a_i$,如果存在两个正整数 $x$ 和 $y$ 满足 $x\times x+y \times y=a_i$,输出
Yes
,否则输出No
。
输入 #1
1
2
3
2
5
4
输出 #1
1
2
Yes
No
说明/提示
对于第一个正整数,存在 $1\times 1+2 \times 2=5$,因此答案为 Yes
。
对于全部数据,保证有 $1 \le n \le 10,1 \le a_i \le 10^6$。
题目分析
解题思路
- 读取输入的正整数数量 $n$。
- 遍历每个正整数 $a_i$。
- 对于每个 $a_i$,初始化一个标志变量,用于标志是否找到满足条件的 $x$ 和 $y$。
- 遍历可能的 $x$ 值,从 $1$ 到 $\sqrt{a_i}$。
- 对于每个可能的 $x$ 值,计算可能的 $y$ 值:$y = \sqrt{a_i - x^2}$。
- 如果 $y$ 是整数(即强转后,不丢失小数位,所以可以验证原等式)且不为 $0$,则标志变量为真,退出循环。
- 根据标志变量的值,输出
Yes
或No
。
示例代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include <cmath>
#include <iostream>
using namespace std;
int main() {
int n; // 输入的正整数数量
cin >> n; // 读取输入的正整数数量
int a1; // 每个正整数
for (int i = 1; i <= n; i++) { // 遍历每个正整数
cin >> a1; // 读取每个正整数
bool flag = false; // 标志是否找到满足条件的x和y
for (int k = 1; k * k < a1; k++) { // 遍历可能的x值
double r = sqrt(a1 - k * k); // 计算可能的y值
int d = (int)r; // 将y值转换为整数
if (d * d + k * k == a1 && d != 0) { // 判断是否满足条件
flag = true; // 如果满足条件,则标志为true
break; // 并退出循环
}
}
if (flag) { // 如果找到满足条件的x和y
cout << "Yes" << endl; // 输出Yes
} else { // 如果没有找到满足条件的x和y
cout << "No" << endl; // 输出No
}
}
return 0;
}
所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code
GESP各级别考纲要点、知识拓展和练习题目清单详见C++学习项目主页
“luogu-”系列题目已加入洛谷Java、C++初学团队,作业清单,可在线评测,团队名额有限,欢迎加入。
“bcqm-”系列题目可在编程启蒙题库进行在线评测。
本文由作者按照 CC BY 4.0 进行授权