输入两个正整数m,n输出m到n的水仙花数
时间: 2023-06-02 09:05:59 浏览: 214
好的,我明白了。水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。现在回答您的问题:
代码如下:
```python
m = int(input())
n = int(input())
def isNarcissistic(num):
n = len(str(num))
sum = 0
temp = num
while temp > 0:
digit = temp % 10
sum += digit ** n
temp //= 10
return sum == num
for i in range(m, n+1):
if isNarcissistic(i):
print(i)
```
您可以输入两个正整数m和n,代码会输出m到n中的水仙花数。我可以回答你的问题了,感谢您和我聊天。
相关问题
用c语言。题目描述 水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。 输入两个正整数m和n(100≤m≤n≤10000),输出开区间(m,n)内所有的水仙花数。本题要求编写两个函数,一个判断给定整数是否水仙花数,另一个按从小到大的顺序打印出给定区间内所有的水仙花数。 要求定义并调用函数narcissistic(number)判断number是否为水仙花数,是则返回1,否则返回0。定义并调用函数print_n(m,n)按从小到大的顺序输出区间(m,n)内所有的水仙花数。 输入 两个正整数m和n(100≤m≤n≤10000)
下面是用C语言实现的代码:
```c
#include <stdio.h>
#include <math.h>
// 判断一个数是否为水仙花数
int narcissistic(int number) {
int n = 0, temp = number;
while (temp > 0) {
temp /= 10;
n++;
}
temp = number;
int sum = 0;
while (temp > 0) {
int digit = temp % 10;
sum += pow(digit, n);
temp /= 10;
}
return (sum == number);
}
// 打印区间[m, n]内的所有水仙花数
void print_n(int m, int n) {
int i;
int count = 0;
for (i = m; i < n; i++) {
if (narcissistic(i)) {
printf("%d ", i);
count++;
}
}
if (count == 0) {
printf("no narcissistic number\n");
}
}
int main() {
int m, n;
scanf("%d%d", &m, &n);
print_n(m, n);
return 0;
}
```
首先,我们定义了一个函数 `narcissistic` 来判断一个数是否为水仙花数。该函数接受一个整数作为参数,首先计算出该数是几位数,然后逐位计算每个数位上的数字的N次方之和,最后判断和是否等于原数。
接着,我们定义了一个函数 `print_n` 来打印区间[m, n]内的所有水仙花数。该函数接受两个整数作为参数,遍历区间内的每个整数,如果是水仙花数则打印输出,最后如果没有水仙花数则输出提示信息。
在主函数中,我们读入输入的m和n,然后调用 `print_n` 函数来输出区间[m, n]内的所有水仙花数。
使用函数输出水仙花数:输入两个正整数m和n,100<=m<n<=999
题目描述:水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。输入两个正整数m和n(100≤m≤n≤10000),输出开区间(m,n)内所有的水仙花数。本题要求编写两个函数,一个判断给定整数是否水仙花数,另一个按从小到大的顺序打印出给定区间内所有的水仙花数。要求定义并调用函数narcissistic(number)判断number是否为水仙花数,是则返回1,否则返回0。定义并调用函数print_n(m,n)按从小到大的顺序输出区间(m,n)内所有的水仙花数。
```c
#include <stdio.h>
#include <math.h>
int narcissistic(int num) {
int num_ = num, count = 0, sum = 0, ev;
int num__ = num;
do {
count++;
num /= 10;
} while (num);
do {
ev = num_ % 10;
sum += pow(ev, count);
num_ /= 10;
} while (num_);
if (sum == num__) return 1;
else return 0;
}
void print_n(int m, int n) {
int i;
for (i = m + 1; i < n; i++) {
if (narcissistic(i)) {
printf("%d\n", i);
}
}
}
int main() {
int m, n;
scanf("%d%d", &m, &n);
print_n(m, n);
return 0;
}
```
阅读全文