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

2024-05-07

水仙花数是指一个n位数,其各位数字的n次幂之和等于该数本身。比如三位数153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。

以下是一个用C语言实现水仙花数的程序:

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

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

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

    originalNum = num;

    // 计算这个数是几位数
    while (originalNum != 0) {
        originalNum /= 10;
        ++n;
    }

    originalNum = num;

    // 计算各位数字的n次幂之和
    while (originalNum != 0) {
        remainder = originalNum % 10;
        result += pow(remainder, n);
        originalNum /= 10;
    }

    // 判断是否为水仙花数
    if (result == num) {
        printf("%d 是水仙花数。\n", num);
    } else {
        printf("%d 不是水仙花数。\n", num);
    }

    return 0;
}

运行程序后,输入一个整数,程序会判断该整数是否为水仙花数。

《c语言水仙花数程序怎么实现.doc》

下载本文的Word格式文档,以方便收藏与打印。