C语言:输出“水仙花数”
题目:输出100到1000的水仙花数。
背景:水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身
1^3 + 5^3+ 3^3 = 153
思路:采用 for 循环,利用数学知识。
代码:
//5.水仙花数(在100-1000中的水仙花数)
#include<stdio.h>
#include<math.h> //引用数学的头文件
int main()
{
int i = 100;
int ge_wei = 0; //初始化,个位
int shi_wei = 0;//初始化,十位
int bai_wei = 0;//初始化,百位
for (i = 100; i <= 1000; i++)
{
ge_wei = i % 10; //求出个位
shi_wei = (i / 10) % 10; //求出十位
bai_wei = (i / 100) % 10; //求出百位
//判断
if (i == pow(ge_wei, 3) + pow(shi_wei, 3) + pow(bai_wei, 3))
{
printf("%d ", i);
}
}
return 0;
}
细节:pow( x , y )是求次方,为 x 的 y 次方。
还没有评论,来说两句吧...