c语言水仙花数程序怎么实现
水仙花数是指一个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;}
运行程序后,输入一个整数,程序会判断该整数是否为水仙花数。