引言
相信大家听到水仙花数这个术语,就会联想到水仙花,终归是好的。
但实际上并不是这样,在C语言中,水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
一、题目描述
打印 1~10000 之间的所有的水仙花数,用空格隔开。
二、题目分析
思路:
1. 输入并保存原始的数值 num,并计算数值 num 的位数 n;(这里可以使用一个循环,每次将num除以 10 ,并将n加 1 ,直到num为 0)
2. 再用一个循环计算每个位上数字的n次幂之和。这里使用了 pow函数 来计算幂次方。
3. 判断计算得到的结果是否等于原始的数值num,如果相等则返回1,表示是水仙花数,否则返回0,表示不是水仙花数。
补充 :pow()函数
函数原型如下:
double pow(double x, double y);
解释:
1. pow函数接受两个参数,x表示底数,y表示指数;
x -- 基数的浮点值;
y -- 指数的浮点值。
2. 用法:返回 x 的 y 次幂;
3. 返回值:函数返回 x 的 y 次幂的结果。
三、应用举例:
使用pow函数计算一个数的平方和立方。
代码示例
#include <stdio.h>
#include <math.h>
int main() {
double num = 2.0;
double square = pow(num, 2);
double cube = pow(num, 3);
printf("平方:%.2lf\n", square); // %.2lf ,输出结果保留两位小数
printf("立方:%.2lf\n", cube);
return 0;
}
运行结果
四、题目代码
代码示例
#include<stdio.h>
#include<math.h>//pow()
// 判断一个数是否为水仙花数
int isArmstrong(int num)
{
int originalNum, remainder, result = 0, n = 0;
originalNum = num;
// 计算数字的位数
while (originalNum != 0)
{
originalNum /= 10;
++n;
}
originalNum = num;
// 计算每位数字的n次幂之和
while (originalNum != 0)
{
remainder = originalNum % 10;
result += pow(remainder, n);/*pow()函数:指数函数(x的y次方)
double pow(double x, double y)
double x 为底数,double y 为指数*/
originalNum /= 10;
}
// 判断是否为水仙花数
if (result == num)
return 1; // 是水仙花数
else
return 0; // 不是水仙花数
}
int main()
{
int i = 0;
printf("水仙花数:\n");
for (i = 1; i < 10000; i++)
{
if (isArmstrong(i))
{
printf("%d ", i);
}
}
return 0;
}
运行结果
五、结语
希望这篇文章对大家有所帮助,如果你有任何问题和建议,欢迎在评论区留言,这将对我有很大的帮助。
完结!咻咻~~