水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。 本题要求编写两个函数,一个判断给定整数是否水仙花数,另一个按从小到大的顺序打印出给定区间(m,n)内所有的水仙花数

void PrintN( int m, int n ){
int i;
if(m==n){
if(narcissistic(m)==1){
printf("%d",m);
}
}else{
for(i=m+1;i<=n;i++){
if(narcissistic(i)==1){
printf("%d\n",i);
}
}
}
}
int narcissistic( int number ){
int a=number%10;
int b=(number/10)%10;
int c=(number/100)%10;
int d=(number/1000)%10;
if(aaa+bbb+ccc+ddd==number){
return 1;
}else{
return 0;
}
}

在函数里调用函数不行吗?为什么输出总是153 到407之间的素数

水仙花数是指一个N位正整数(N≥3)
每个位上的数字的N次幂 ==> 4位数就要4次方,5位数就要5次方

if(aaa+bbb+ccc+ddd==number){ 《==这个判断是不对的

#include <stdio.h>
#include <math.h>

int narcissistic( int number ){
    int t, count = 1, sum = 0;
    t = number;
    while (t/10 > 0){
        count++;
        t /= 10;
    }
    t = number;
    while (t/10 > 0){
        sum += pow(t%10,count);
        t /= 10;
    }
    sum += pow(t%10,count);
    return sum==number;
}

int main(void)
{
    for (int i=1;i<=10000;i++){
        if (narcissistic(i)){
            printf("%d\n",i);
        }
    }
    
    return 0;
}