【GESP】C++二级真题 luogu-b3841, [GESP202306 二级] 自幂数判断
GESP二级真题,多重循环应用,难度★✮☆☆☆。
luogu-B3841 [GESP202306 二级] 自幂数判断
题目要求
题目描述
自幂数是指,一个 $N$ 位数,满足各位数字 $N$ 次方之和是本身。例如,$153$ 是 $3$ 位数,其每位数的 $3$ 次方之和,$1^3+5^3+3^3=153$,因此 $153$ 是自幂数;$1634$ 是 $4$ 位数,其每位数的 $4$ 次方之和,$1^4+6^4+3^4+4^4=1634$,因此 $1634$ 是自幂数。现在,输入若干个正整数,请判断它们是否是自幂数。
输入格式
输入第一行是一个正整数 $M$,表示有 $M$ 个待判断的正整数。约定 $1 \le M \le 100$。
从第 $2$ 行开始的 $M$ 行,每行一个待判断的正整数。约定这些正整数均小于 $10^8$。
输出格式
输出 $M$ 行,如果对应的待判断正整数为自幂数,则输出英文大写字母 $\texttt T$,否则输出英文大写字母 $\texttt F$。
提示
不需要等到所有输入结束在依次输出,可以输入一个数就判断一个数并输出,再输入下一个数。
样例输入 #1
1
2
3
4
3
152
111
153
样例输出 #1
1
2
3
F
F
T
样例输入 #2
1
2
3
4
5
6
5
8208
548834
88593477
12345
5432
样例输出 #2
1
2
3
4
5
T
T
T
F
F
题目分析
解题思路
- 首先读取输入的整数个数 $n$。
- 使用一个循环来遍历每个输入的整数。
- 对于每个整数,首先计算其位数 $pows$。
- 然后计算每个位数的 $pows$ 次方和 $sum$。
- 如果 $sum$ 等于当前整数,输出 “T”,否则输出 “F”。
示例代码
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
28
29
30
31
#include <cmath>
#include <iostream>
using namespace std;
int main() {
int n; // 输入的整数个数
cin >> n; // 读取输入的整数个数
for (int i = 0; i < n; i++) { // 遍历每个输入的整数
int m; // 当前输入的整数
cin >> m; // 读取当前输入的整数
int copy_m = m; // 复制当前输入的整数
int pows = 0; // 计算当前输入的整数的位数
while (copy_m != 0) { // 计算位数
copy_m /= 10;
pows++;
}
int sum = 0; // 计算每个位数的pows次方和
copy_m = m; // 复制当前输入的整数
while (copy_m != 0) { // 计算每个位数的pows次方和
sum += pow(copy_m % 10, pows); // 计算当前位数的pows次方并累加
copy_m /= 10; // 移除当前位数
}
if (sum == m) { // 判断是否为阿姆斯特朗数
cout << "T" << endl; // 是阿姆斯特朗数输出T
} else {
cout << "F" << endl; // 不是阿姆斯特朗数输出F
}
}
return 0;
}
所有代码已上传至Github:https://github.com/lihongzheshuai/yummy-code
GESP各级别考纲要点、知识拓展和练习题目清单详见C++学习项目主页
“luogu-”系列题目已加入洛谷Java、C++初学团队,作业清单,可在线评测,团队名额有限,欢迎加入。
“bcqm-”系列题目可在编程启蒙题库进行在线评测。
本文由作者按照 CC BY 4.0 进行授权