水仙花数是指一个n位数,其各位数字的n次方之和等于该数本身。例如,153是一个三位水仙花数,因为1^3 + 5^3 + 3^3 = 153。 以下是输出所有n位水仙花数的代码
时间: 2023-06-19 10:05:27 浏览: 151
以下是输出所有n位水仙花数的 Python 代码:
```python
def get_narcissistic_numbers(n):
results = []
for i in range(10**(n-1), 10**n):
sum_of_powers = sum([int(digit)**n for digit in str(i)])
if sum_of_powers == i:
results.append(i)
return results
```
你只需要调用 `get_narcissistic_numbers(n)` 函数,传入参数 `n` 即可输出所有 n 位水仙花数。例如,要输出所有 3 位水仙花数,可以调用 `get_narcissistic_numbers(3)`。
相关问题
//水仙花数是指一个n位数,其各位数字的n次方之和等于该数本身,如:1^3 + 5^3+ 3^3 = 153,求100-999中的水仙花数,c++
在C++中,我们可以编写一个函数来检查一个三位数是否是水仙花数。这是一个简单的遍历过程,对于每个三位数,我们分别提取百位、十位和个位的数字,计算它们的立方和,然后比较结果是否等于原始数字。
以下是相应的代码片段:
```cpp
#include <iostream>
using namespace std;
bool is narcissistic(int num) {
int digits[3]; // 用于存储每一位的数字
int sum = 0;
// 提取并计算每一位的立方和
while(num > 0) {
digits[2] = num % 10;
sum += digits[2]*digits[2]*digits[2];
num /= 10;
}
// 检查是否为水仙花数
return sum == num;
}
int main() {
for(int i = 100; i < 1000; ++i) { // 遍历100-999范围内的数
if(is_narcissistic(i)) {
cout << i << " is a narcissistic number." << endl;
}
}
return 0;
}
用C语言编写一段求出 0~100000 之间的所有“水仙花数”并输出“水仙花数”是指一个 n 位数,其各位数字的 n 次方之和确好等于该数本身
#include <stdio.h>
int main() {
int i, j, k, n, sum;
for (i = 0; i <= 9; i++) {
sum = i * i * i;
if (sum == i) {
printf("%d ", i);
}
}
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
sum = i * i * i + j * j * j;
if (sum == i * 10 + j) {
printf("%d ", i * 10 + j);
}
}
}
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
sum = i * i * i + j * j * j + k * k * k;
if (sum == i * 100 + j * 10 + k) {
printf("%d ", i * 100 + j * 10 + k);
}
}
}
}
for (n = 4; n <= 6; n++) {
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
sum = i * i * i + j * j * j + k * k * k;
if (sum == i * 100 + j * 10 + k) {
printf("%d ", i * 100 + j * 10 + k);
}
}
}
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
sum = i * i * i + j * j * j + k * k * k;
if (sum == i * 1000 + j * 100 + k * 10 + i) {
printf("%d ", i * 1000 + j * 100 + k * 10 + i);
}
}
}
}
}
return 0;
}
阅读全文
相关推荐















