使用函數輸出水仙花數


水仙花數是指一個N位正整數(N3),它的每個位上的數字的N次冪之和等於它本身。例如:153=13+53+33。 本題要求編寫兩個函數,一個判斷給定整數是否水仙花數,另一個按從小到大的順序打印出給定區間(m,n)內所有的水仙花數。


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

int narcissistic( int number );
void PrintN( int m, int n );

int main()
{
int m, n;

scanf("%d %d", &m, &n);
if ( narcissistic(m) ) printf("%d is a narcissistic number\n", m);
PrintN(m, n);
if ( narcissistic(n) ) printf("%d is a narcissistic number\n", n);

return 0;
}

int narcissistic( int number ){
int i,n=0,sum=0,cnt=0;
n = number;
while(n){
cnt++;
n/=10;
}

n = number;
while(n){
i=n%10;
sum += (int)pow(i, cnt);
n/=10;
}

if(sum == number)
return 1;
else
return 0;

}

void PrintN( int m, int n ){

int i;

for(i=m+1;i<n;i++)
if(narcissistic(i))
printf("%d\n", i);
}
————————————————
版權聲明:本文為CSDN博主「reading_code_man」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/u013243314/article/details/73480100

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM