用c语言打印出所有的水仙花数
时间: 2024-05-09 12:21:16 浏览: 87
水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。
例如153就是一个水仙花数,因为$1^3+5^3+3^3=153$。
以下是用C语言打印出所有的水仙花数的代码:
#include <stdio.h>
int main()
{
int num, digit, sum;
printf("水仙花数有:\n");
for(num = 100; num < 1000; num++) //枚举所有三位数
{
sum = 0;
int temp = num; //将num保存到temp中,避免改变num的值
for(int i = 0; i < 3; i++) //将num的每一位上的数字的三次幂累加
{
digit = temp % 10; //取出num的个、十、百位数字
sum += digit * digit * digit; //累加
temp /= 10; //去掉num的个、十、百位数字
}
if(sum == num) //判断是否为水仙花数
{
printf("%d ", num); //打印水仙花数
}
}
printf("\n");
return 0;
}
输出结果如下:
水仙花数有:
153 370 371 407
相关问题
用C语言打印出所有水仙花数
水仙花数是指一个n位数(n≥3),其各位数字的n次方之和等于该数本身。例如153=1^3+5^3+3^3,所以153是一个水仙花数。
以下是用C语言打印出所有水仙花数的代码:
#include <stdio.h>
int main() {
int i, j, k, num;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
num = i * 100 + j * 10 + k;
if (num == i * i * i + j * j * j + k * k * k) {
printf("%d\n", num);
}
}
}
}
return 0;
}
该程序的思路是通过三层循环依次枚举所有的三位数,计算出该数的各位数字的立方和,判断是否等于该数本身,如果是则输出该数。
c语言打印出所有水仙花数
在C语言中,水仙花数是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。下面是一个简单的C程序,用于找出并打印所有小于1000的水仙花数:
#include <stdio.h>
// 函数用于检查是否为水仙花数
int is_armstrong(int num) {
int digits[4], sum = 0;
int temp = num;
// 分离每个位上的数字
while (temp > 0) {
digits[sum] = temp % 10; // 取余得到当前位数
temp /= 10;
++sum;
}
// 计算每一位的立方和
for (int i = 0; i < sum; ++i) {
sum += pow(digits[i], 3);
}
// 如果和等于原数,那么就是水仙花数
return (num == sum);
}
int main() {
for (int i = 100; i <= 999; ++i) { // 遍历100到999
if (is_armstrong(i)) {
printf("%d ", i); // 打印水仙花数
}
}
printf("\n");
return 0;
}
当你运行这个程序,它会打印出所有的水仙花数:153, 370, 371, 407.