计算机程序水仙花数,水仙花数

水仙花数(Narcissistic number)也被称为超完全数字不变数(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。

中文名

水仙花数

外文名

Narcissistic number别    名

pluperfect digital invariant

学    科

数学、计算机

水仙花数基本信息

编辑

语音

水仙花数定义

水仙花数只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。

附:其他位数的自幂数名字

一位自幂数:独身数

两位自幂数:没有

三位自幂数:水仙花数

四位自幂数:四叶玫瑰数

五位自幂数:五角星数

六位自幂数:六合数

七位自幂数:北斗七星数

八位自幂数:八仙数

九位自幂数:九九重阳数

十位自幂数:十全十美数

水仙花数常见水仙花数

水仙花数又称阿姆斯特朗数。

三位的水仙花数共有4个:153,370,371,407;

四位的四叶玫瑰数共有3个:1634,8208,9474;

五位的五角星数共有3个:54748,92727,93084;

六位的六合数只有1个:548834;

七位的北斗七星数共有4个:1741725,4210818,9800817,9926315;

八位的八仙数共有3个:24678050,24678051,88593477

……

使用高精度计算,可以得到超过int类型上限的水仙花数:

5: 93084

5: 92727

5: 54748

6: 548834

7: 9800817

7: 4210818

7: 1741725

7: 9926315

8: 24678050

8: 24678051

8: 88593477

9: 146511208

9: 472335975

9: 534494836

9: 912985153

10: 4679307774

11: 32164049650

11: 40028394225

11: 42678290603

11: 49388550606

11: 32164049651

11: 94204591914

11: 44708635679

11: 82693916578

14: 28116440335967

16: 4338281769391370

16: 4338281769391371

17: 21897142587612075

17: 35641594208964132

17: 35875699062250035

19: 1517841543307505039

19: 3289582984443187032

19: 4929273885928088826

19: 4498128791164624869

20: 63105425988599693916

21: 449177399146038697307

21: 128468643043731391252

23: 27907865009977052567814

23: 35452590104031691935943

23: 27879694893054074471405

23: 21887696841122916288858

24: 174088005938065293023722

24: 188451485447897896036875

(为环保起见,24位以上的水仙花数略)

最大的水仙花数有39位。十进制自然数中的所有水仙花数共有88个。

水仙花数求取方法

编辑

语音

(非高精度)

以下为在各种编程语言中实现求取水仙花数的方法(非高精度)。

水仙花数C 实现

//方法一

#include

#include

#include

int cube(const int n){

return n*n*n;

}

bool

isNarcissistic(const int n){//判断是不是水仙花数

int hundreds=n/100;

int tens=n/10-hundreds*10;

int ones=n%10;

return cube(hundreds)+cube(tens)+cube(ones)==n;

}

int main(void){

int i;

for(i=100;i<1000;++i){

if(isNarcissistic(i))

printf("%d\n",i);

}

return 0;

}//方法二

#include 

#include 

int main()

{

int i,j,k,n;

printf("'water flower'number is:");

for(n=100;n<1000;n++)

{

i=n/100;/*分解出百位*/

j=n/10%10;/*分解出十位*/

k=n%10;/*分解出个位*/

if(n==i*i*i+j*j*j+k*k*k)

{

printf("%-5d",n);

}

}

printf("\n");

return 0;

}

水仙花数C++ 实现

//一:C++中水仙花数实现代码

#include

using std::cout;

using std::endl;

#define f(a) (a)*(a)*(a)

int main() {

for (int i = 100;i 

if (f(i % 10) + f(i / 10 % 10) + f(i / 100 % 10) == i)

cout <

system("pause");

return 0;

}//二:C++中任意位数水仙花数实现代码

#include

#include

using namespace std;

int main(])

{

long n1, n2, a;

int i;

cout <

cin >> i;

cout <

for (n1 = pow(10, i - 1); n1 

{

n2 = 0;

for (int j=0; j 

{

a = pow(10, j);

a =

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值