一:什么是水仙花数
水仙花数,也称为自恋数或者自幂数,是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。
具体而言,对于一个三位数abc来说,如果满足 abc = a^3 + b^3 + c^3,则它就是一个水仙花数。
二:代码
#include<stdio.h>
int main(){
//在100-1000之间寻找水仙花数,每个位上得数字的立方和等于该数本身
int sum;
int num;
printf("水仙花数有:\n");
for(num = 100;num < 1000;num++){
//将三位数拆分为个位、十位和百位数
//例如153
int digit_1 = num /100; //153的1,153/100=1...53,int 取整为1
int digit_2 = (num /10)%10;//153的5,153/10=15, 15%10=1...5(取余)
int digit_3 = num % 10 ;//153的3,153%10=15...3(取余)
//计算三位数的立方和
int sum = digit_1*digit_1*digit_1 +
digit_2*digit_2*digit_2+
digit_3*digit_3*digit_3;
//判断立方和是否与原始数相等
if(sum == num){
printf("%d\n",num);
}
}
return 0;
}
三:结果
以上