温馨提示×

c语言水仙花数编程怎么实现

小亿
83
2024-08-17 10:30:36
栏目: 编程语言

水仙花数,也称为自恋数或者阿姆斯特朗数,是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。

下面是一个用C语言编程实现水仙花数的示例代码:

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

int isArmstrong(int num) {
    int originalNum, remainder, n = 0, result = 0;

    originalNum = num;

    while (originalNum != 0) {
        originalNum /= 10;
        ++n;
    }

    originalNum = num;

    while (originalNum != 0) {
        remainder = originalNum % 10;
        result += pow(remainder, n);
        originalNum /= 10;
    }

    if (result == num) {
        return 1;
    } else {
        return 0;
    }
}

int main() {
    int num;

    printf("请输入一个数字:");
    scanf("%d", &num);

    if (isArmstrong(num)) {
        printf("%d 是水仙花数。\n", num);
    } else {
        printf("%d 不是水仙花数。\n", num);
    }

    return 0;
}

运行该代码,输入一个数字,程序会判断该数字是否为水仙花数,并输出结果。

0