题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数
本身。例如:153是一个“水仙花数”,因为153 = 1的三次方+5的三次方+3的三次方。
程序分析:判断一个三位数是不是水仙花数,只需要把其百位,十位和个位的数字分离出来,然后判断其各位数字立方和是否等于该数本身。本题关键是把百位,十位和个位的数字分离,然后利用循环语句和条件判断语句进行查找和判断即可。
代码:
#include<stdio.h>
int main()
{
int bai, shi, ge;
int i, j=0;
printf("水仙花数有:\n");
for (i = 100;i < 1000;i++)
{
bai = i / 100; //取百位数字
shi = (i % 100) / 10;//取十位数字
ge = i % 10; //取个位数字
if (i == bai * bai * bai + shi * shi * shi + ge * ge * ge)//判断是否满足水仙花数的特点
{
printf(" %d ", i);
j++;
if (j % 5 == 0)//每五个数字一行
printf("\n");
}
}
return 0;
}
运行结果: