C 练习实例13 - 水仙花数
题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数 本身。例如: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;
}
#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;
}