水仙花数
Posted LWB
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了水仙花数相关的知识,希望对你有一定的参考价值。
2017-04-1518:32:37
- 问题描述:打印所有的“水仙花数” 。所谓“水仙花数”是指一个三位数,其各位数字的立方和等于该数本身。
例如:153是“水仙花数”。因为153=13+33+53。
2.【算法思想】
首先,确定水仙花数n可能存在的范围,因为n是一个三位数,所以范围确定为 n 从 100 变化到 999。
其次,分离出 n 的百位 i、十位 j、个位 k 后,只要判断 n 是否等于i*i*i+j*j*j+k*k*k 即可知道 n 是否是水仙花数。
3 、代码在vs2012中运行代码
#include <stdio.h>
#include "stdlib.h"
int main ( )
{
int i,j,k,n;
printf( " The result is :");
for( n=100;n<1000;n++)
{
i=n/100; /*分出百位*/
j=(n-i*100)/10; /*分出十位*/
k=n%10; /*分出个位之前出错的地方*/
if (i*100+j*10+k==i*i*i+j*j*j+k*k*k)
{
printf("%d",n ); /*输出结果*/
}
}
system("pause"); /*解决快闪问题*/
}
4、总结:上述代码是在vs2012c++环境运行的,需要定义int main(),在其他环境运行需要根据要求自己修改。
result is:153 370 371 407
以上是关于水仙花数的主要内容,如果未能解决你的问题,请参考以下文章