本文主要是介绍求0~999之间的水仙花数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
//求出0~999之间的水仙花数并
先了解一下什么是水仙花数?
水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身如:153=1^3+5^3+3^3,则153是一个仙花数”。
解题思路:1> 将三位数分解成:百位、十位、个位;
2> 分别定义三个变量来代表百位、十位、个位;
3> 采用除和求模的方式分别求出个十百位;
4> 使用pow函数求次方,输出结果。
源代码:
#include<stdio.h>
#include<stdlib.h>
#include<math.h>//求出0~999之间的水仙花数并输出
//水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身
//如:153=1^3+5^3+3^3,则153是一个“水仙花数”
//分别求出百位、十位、个位,在求和
int main()
{int hundred = 0;int decade = 0;int unit = 0;int i = 0;//水仙花数指三位数,直接排除0~99,从100开始for (i = 100; i < 1000; i++){//百位hundred = i / 100;//十位decade = (i / 10) % 10;//个位unit = i % 10;if (i == pow(hundred, 3) + pow(decade, 3) + pow(unit, 3)){printf("%d\n", i);}}system("pause");return 0;
}
运行结果:
这篇关于求0~999之间的水仙花数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!