c语言—阿姆斯特朗数/水仙花数

阿姆斯特朗数也就是俗称的水仙花数,是指一个三位数,其各位数字的立方和等于该数本身。例如:153=13+53+33,所以 153 就是一个水仙花数。求出所有的水仙花数。

算法思想

对于阿姆斯特朗数问题,根据水仙花数的定义,需要分离出个位数、十位数和百位数。然后按其性质进行计算并判断,满足条件则打印输出,否则不打印输出。

因此,阿姆斯特朗数问题可以利用循环语句解决。设循环变量为 i,初值为 100,i 从 100 变化到 1000;依次判断条件是否成立,如果成立则输出,否则不输出。

算法思想具体如下:
① 分离出个位数,算术表达式为:j=i%10。
② 分离出十位数,算术表达式为:k=i/10%10。
③ 分离出百位数,算术表达式为:n=i/100。
④ 判断条件是否成立。若是,执行步骤 ⑤;若不是,执行步骤 ⑥。
⑤ 打印输出结果。
⑥ i 自增 1。
⑦ 转到 ① 执行,直到 i 等于 1000。

其判断的条件为:j*j*j+k*k*k+n*n*n==i。

程序代码

运行实例

#include <stdio.h>
int main()
{
    int i,j,k,n;
    for(i=100;i<1000;i++)
    {
        j=i%10;
        k=i/10%10;
        n=i/100;
        if(j*j*j+k*k*k+n*n*n==i)
            printf("%5d\n",i);
    }
    return 0;
}

调试运行结果

所有的阿姆斯特朗数,如下所示:
  153
  370
  371
  407

总结

实训中需注意的是在分离个位数、十位数和百位数时,算术运算符的选择。要清楚每一种算术运算符的运算规则和结合性,再根据题意选择合适的算术运算符进行运算。在本实例中使用了除法运算符“/”和求余运算符(模运算符)“%”。

在程序中由于循环体的语句不止一句,因此我们在使用时必须用“{}”括起来,组成复合语句进行使用。在程序中应把复合语句看成是单条语句而不是多条语句,复合语句内的各条语句都必须以分号“;”结尾;此外,在括号“}”外不能加分号。一般复合语句用于要执行某段特殊功能的程序如 for 语句、if 语句或 while 语句等。

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: 水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。 要解决水仙花数问题,可以使用C语言编写一个程序来进行计算。以下是一个使用for循环的C语言程序示例: ``` #include <stdio.h> int main() { int n, sum, i, j, k; printf("输入最大的数值:"); scanf("%d", &n); printf("水仙花数为:"); for(i = 1; i <= n; i++) { sum = 0; j = i; while(j > 0) { k = j % 10; sum += k * k * k; j /= 10; } if(sum == i) { printf("%d ", i); } } return 0; } ``` 在上面的代码中,程序会要求用户输入最大的数值,然后使用for循环计算每个数是否是水仙花数。如果找到一个水仙花数,程序会将其输出。 ### 回答2: 水仙花数是指一个三位数,它的每个数字的立方和等于它本身。例如,153就是一个水仙花数,因为1的立方+5的立方+3的立方等于153。如果要用C语言解决水仙花数问题,可以采用以下方法: 1. 创建一个函数来检查一个三位数是否为水仙花数。首先,将这个三位数拆解为个位、十位和百位数。然后,将每个数字的立方相加,与原始数进行比较。如果相等,则说明这个数是水仙花数,返回结果为真;否则,返回结果为假。 2. 在主函数中,遍历所有可能的三位数(从100到999)。对于每个三位数,调用上述函数进行检查。如果返回结果为真,则将这个数打印出来表示找到了一个水仙花数。 以下是一个C语言解决水仙花问题的代码示例: ```c #include <stdio.h> int isNarcissistic(int num) { int digit1, digit2, digit3; digit1 = num % 10; // 个位数 digit2 = (num / 10) % 10; // 十位数 digit3 = (num / 100) % 10; // 百位数 if (num == (digit1 * digit1 * digit1 + digit2 * digit2 * digit2 + digit3 * digit3 * digit3)) { return 1; // 是水仙花数 } else { return 0; // 不是水仙花数 } } int main() { int num; printf("水仙花数有:\n"); for (num = 100; num <= 999; num++) { if (isNarcissistic(num)) { printf("%d\n", num); } } return 0; } ``` 以上代码在主函数中遍历从100到999的三位数,并通过调用isNarcissistic函数检查每个数是否为水仙花数。如果是,则输出这个数。运行结果将打印出所有的水仙花数。 ### 回答3: 水仙花数,也被称为自恋数或阿姆斯数,是指一个n位数(n≥3),它的各位数字的立方和等于它本身。例如,153是一个水仙花数,因为1³ + 5³ + 3³ = 153。 要用C语言解决水仙花数问题,可以采取以下步骤: 1. 导入所需的头文件: #include <stdio.h> #include <math.h> 2. 声明变量: int num, originalNum, remainder, result = 0, n = 0; 3. 用户输入一个数字: printf("请输入一个整数:"); scanf("%d", &num); originalNum = num; 4. 计算数字的位数: while (originalNum != 0) { originalNum /= 10; ++n; } 5. 计算各位数字的立方和: originalNum = num; while (originalNum != 0) { remainder = originalNum % 10; result += pow(remainder, n); originalNum /= 10; } 6. 判断是否是水仙花数: if (result == num) printf("%d是水仙花数\n", num); else printf("%d不是水仙花数\n", num); 以上就是用C语言解决水仙花数问题的简单步骤,它根据用户输入的数字,计算各位数字的立方和,并将结果与原始输入进行比较,最后给出判断结果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力进步的小姜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值