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;
}
C 语言经典100例
cfp
woa***opoyingzi@163.com
参考方法:
#include<stdio.h> int main(void) { int sum, x, y, z; for(x=1;x<10;x++) for(y=0;y<10;y++) for(z=0;z<10;z++) { sum=100*x+10*y+z; if(sum==x*x*x+y*y*y+z*z*z) printf("%4d",sum); } return 0; }cfp
woa***opoyingzi@163.com
zayn
267***5830@qq.com
参考方法:
#include<stdio.h> #include<math.h> void f11(){ int i=0; for(i=100;i<=999;i++){ int a=i/100; int b=i%100/10; int c=i%10; double temp=pow(a,3)+pow(b,3)+pow(c,3); if(temp==i){ printf("%d\n",i); } } } int main(){ f11(); return 0; }zayn
267***5830@qq.com
卿卿卿姐姐
631***104@qq.com
参考方法:
#include<stdio.h> int main(void) { int i, s, n, q; for(i = 101; i < 1000; i++) { s = 0; q = i; while(q != 0) { n = q % 10; s += n*n*n; q /= 10; } if( s == i) printf("%d是水仙花数\n", i); } return 0; }卿卿卿姐姐
631***104@qq.com
HIT_CCC
117***2963@qq.com
参考方法:
#include<stdio.h> int IsSXH(int n) { int a,b,c,num; num = n; c = n%10; n = n/10; b = n%10; a = n/10; if(num == a*a*a + b*b*b + c*c*c) return 1; else return 0; } int main(void) { int i; for(i = 100; i < 1000; i++) { if(IsSXH(i)) printf("%d\n",i); } return 0; }HIT_CCC
117***2963@qq.com
ronnyz
221***8677@qq.com
参考方法:
#include <stdio.h> #include <math.h> int main(){ int i,temp; double sum; for(i=100;i<1000;i++){ sum=0; temp=i; while(temp){ sum+=pow(temp%10,3); temp/=10; } if((int)sum==i) printf("%d ",i); } return 0; }ronnyz
221***8677@qq.com