水仙花数是指一个n位数(n>=3),它的每个位上的数字的n次幂之和等于它本身。
(注意此处若为四位数,则是4次方)
例如:1^3+5^3+3^3=153;
求输入的数字是否为水仙花数。
// 功能:判断输入nValue 是否为水仙花数
// 输入:nValue为正整数
// 输出:无
// 返回:如果输入为水仙花数,返回1,否则返回0
<pre name="code" class="cpp">unsigned int func(int n,int m)
{
unsigned int mi=1;
for (int i=1;i<=m;i++)
{
mi=mi*n;
}
return mi;
}
unsigned int IsDaffodilNum(unsigned int nValue)
{
int c,n=1;
unsigned b=nValue,a=nValue,sum=0;
while (a>=10)
{
a/=10;
n++;
}
while(b>=1)
{
c=b%10;
b/=10;
sum=sum+func(c,n);
}
if(nValue==sum)
return 1;
else
return 0;
}
</pre><pre code_snippet_id="345405" snippet_file_name="blog_20140514_4_3153590" name="code" class="cpp">