水仙花数又称阿姆斯特朗数。 水仙花数是指一个n 位数( n≥3 ),它的每个位上的数字的n 次幂之和等于它本身。(例如:1^3 + 5^3 + 3^3 = 153) 判断输入的数字是否为水仙花数。写一个c++代码
时间: 2023-11-16 16:06:26 浏览: 180
可以使用以下代码来判断一个数是否为水仙花数:
```c++
#include <iostream>
#include <cmath>
using namespace std;
bool isArmstrong(int n) {
int sum = 0;
int digits = floor(log10(n)) + 1;
int temp = n;
while (temp != 0) {
int digit = temp % 10;
sum += pow(digit, digits);
temp /= 10;
}
return sum == n;
}
int main() {
int n;
cout << "请输入一个数字:";
cin >> n;
if (isArmstrong(n)) {
cout << n << " 是水仙花数。" << endl;
} else {
cout << n << " 不是水仙花数。" << endl;
}
return 0;
}
```
代码中,`isArmstrong` 函数用来判断一个数是否为水仙花数,使用了循环和取余运算来计算每个位上的数字的 n 次幂之和。`main` 函数中则是输入一个数字并判断它是否为水仙花数。
相关问题
水仙花数又称阿姆斯特朗数。 水仙花数是指一个n 位数( n≥3 ),它的每个位上的数字的n 次幂之和等于它本身。(例如:1^3 + 5^3 + 3^3 = 153) 判断输入的数字是否为水仙花数。
好的,可以使用以下代码来判断一个数是否为水仙花数:
```python
num = input("请输入一个三位数:") # 获取用户输入
sum = 0 # 初始化和为0
if len(num) != 3: # 判断输入是否为三位数
print("输入错误,请输入一个三位数!")
else:
for i in num: # 遍历每一位数字
sum += int(i) ** 3 # 计算每一位数字的立方和
if sum == int(num): # 判断是否为水仙花数
print(num, "是水仙花数!")
else:
print(num, "不是水仙花数!")
```
以上代码中,我们先获取用户输入的数字,然后判断是否为三位数,如果不是则提示输入错误。如果是三位数,则遍历每一位数字,计算每一位数字的立方和,最后判断是否和原数相等,如果相等则为水仙花数,否则不是。
C语言水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数。水仙花数是指一个 n 位数(n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身,例如:13+ 53+ 33= 153。输入一个三位数,判
断它是否为水仙花数。
可以使用以下代码来判断一个三位数是否为水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main() {
int num, sum = 0, temp;
printf("请输入一个三位数:");
scanf("%d", &num);
temp = num;
while(temp > 0) {
int digit = temp % 10;
sum += pow(digit, 3);
temp /= 10;
}
if(sum == num) {
printf("%d是水仙花数\n", num);
} else {
printf("%d不是水仙花数\n", num);
}
return 0;
}
```
代码中使用了循环和取模运算来分离出三位数的各个数字,并使用 pow 函数计算每个数字的立方和。最后再将计算结果与原数进行比较即可。
阅读全文
相关推荐















