现在位置: 首页 > C 教程 > 正文

C 练习实例13 - 水仙花数

C 语言经典100例 C 语言经典100例

题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数 本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。

程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。

实例

// Created by www.runoob.com on 15/11/9. // Copyright © 2015年 菜鸟教程. All rights reserved. // #include <stdio.h> int main() { int i, x, y, z; // 遍历 100 到 999 的数字 for (i = 100; i < 1000; i++) { // 计算各位数字 x = i % 10; // 个位 y = (i / 10) % 10; // 十位 z = (i / 100) % 10; // 百位 // 计算立方和 int sum = x * x * x + y * y * y + z * z * z; // 判断是否为水仙花数 if (i == sum) { printf("%d\n", i); } } return 0; }

以上实例输出结果为:

153
370
371
407 

以下演示了如何在 C 语言中找到并输出一个指定范围内的水仙花数:

实例

#include <stdio.h>
#include <math.h>

// 函数声明
int countDigits(int num);
int isArmstrong(int num);

int main() {
    int start, end;
   
    // 输入范围
    printf("Enter the start of the range: ");
    scanf("%d", &start);
    printf("Enter the end of the range: ");
    scanf("%d", &end);

    // 输出范围内的水仙花数
    printf("Armstrong numbers between %d and %d are:\n", start, end);
    for (int i = start; i <= end; i++) {
        if (isArmstrong(i)) {
            printf("%d\n", i);
        }
    }

    return 0;
}

// 计算数字的位数
int countDigits(int num) {
    int count = 0;
    while (num != 0) {
        num /= 10;
        count++;
    }
    return count;
}

// 判断一个数字是否为水仙花数
int isArmstrong(int num) {
    int originalNum = num;
    int digits = countDigits(num);
    int sum = 0;

    while (num != 0) {
        int digit = num % 10;
        sum += pow(digit, digits);
        num /= 10;
    }

    return sum == originalNum;
}

C 语言经典100例 C 语言经典100例