五色水仙

注册

 

发新话题 回复该主题

C水仙花数多种实现方法对比 [复制链接]

1#

水仙花数是指一个3位数,它的每个位上的数字的立方和等于它本身,例如:=1^3+5^3+3^3。

C++实现水仙花数

下面是用C++实现水仙花数的5种方法:

1、暴力枚举法:这是最简单的一种方法,只需要枚举所有3位数,判断是否是水仙花数即可。代码如下:

#includeiostream#includecmathusingnamespacestd;intmain(){for(inti=;i=;i++){inta=i/;intb=i/10%10;intc=i%10;if(a*a*a+b*b*b+c*c*c==i){coutiendl;}}return0;}运行结果

2、纯数学方法:由于水仙花数是3位数,所以可以确定它的范围在~之间。又因为它是由3个数字组成的,所以可以通过数学方法来确定它的每一位上的数字,然后判断是否是水仙花数即可。代码如下:

#includeiostream#includecmathusingnamespacestd;intmain(){for(inti=;i=;i++){inta=i/;intb=i/10%10;intc=i%10;if(pow(a,3)+pow(b,3)+pow(c,3)==i){coutiendl;}}return0;}

3、数组方法:可以用数组来存储每一位上的数字,然后通过循环来计算每一位的立方和,并判断是否是水仙花数。代码如下:

#includeiostream#includecmathusingnamespacestd;intmain(){for(inti=;i=;i++){intnum[3];num[0]=i/;num[1]=i/10%10;num[2]=i%10;intsum=0;for(intj=0;j3;j++){sum+=pow(num[j],3);}if(sum==i){coutiendl;}}return0;}

在这段代码中,我们首先使用一个循环遍历所有3位数,然后将每个数的每一位上的数字分别存储到数组num中。接着,使用另一个循环计算数组num中的每一位的立方和,最后判断这个立方和是否等于原数即可。

4、用递归方法实现水仙花数的代码如下:

#includeiostream#includecmathusingnamespacestd;voiddfs(intnum){if(num){return;}inta=num/;intb=num/10%10;intc=num%10;if(pow(a,3)+pow(b,3)+pow(c,3)==num){coutnumendl;}dfs(num+1);}intmain(){dfs();return0;}

在这段代码中,我们定义了一个递归函数dfs,它的作用是遍历所有3位数,并判断是否是水仙花数。

5、用字符串方法实现水仙花数的代码如下:

#includeiostream#includecmath#includestringusingnamespacestd;intmain(){for(inti=;i=;i++){strings=to_string(i);intsum=0;for(intj=0;js.size();j++){sum+=pow(s[j]-0,3);}if(sum==i){coutiendl;}}return0;}

在这段代码中,我们使用了一个小技巧:将字符串中的字符减去字符0后得到的数字就是这个字符代表的数字。例如,字符3减去字符0得到的数字就是3。

以上就是C++实现水仙花数的五种方法,大家学会了吗?

分享 转发
TOP
发新话题 回复该主题