c语言1-1000水仙花数编程
时间: 2023-09-21 20:03:38 浏览: 158
水仙花数是指一个 n 位正整数 (n≥3),它的每个位上的数字的 n 次幂之和等于它本身。
例如:153 = 1^3 + 5^3 + 3^3,371 = 3^3 + 7^3 + 1^3。
以下是 C 语言代码实现 1-1000 的水仙花数:
```c
#include <stdio.h>
#include <math.h>
int main() {
int i, j, k, n;
for (i = 1; i <= 9; i++) {
for (j = 0; j <= 9; j++) {
for (k = 0; k <= 9; k++) {
n = i * 100 + j * 10 + k;
if (n == pow(i, 3) + pow(j, 3) + pow(k, 3)) {
printf("%d ", n);
}
}
}
}
return 0;
}
```
输出结果为:
```
153 370 371 407
```
相关问题
c语言编程所有的水仙花数
在c语言中,可以用以下代码来寻找所有的水仙花数:
#include <stdio.h>
#include <math.h>
int main()
{
int start, end, i, a, b, c, sum;
printf("请输入开始数值:");
scanf("%d", &start);
printf("请输入结束数值:");
scanf("%d", &end);
for (i = start; i <= end; i++) {
a = i / 100; // 求出百位
b = i / 10 % 10; // 求出十位
c = i % 10; // 求出个位
sum = pow(a, 3) + pow(b, 3) + pow(c, 3); // 求出立方和
if (sum == i) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
注意,在代码中,变量a、b、c分别代表百位、十位、个位,sum代表立方和,当sum等于数字本身i时,说明该数字是水仙花数,输出即可。
各位数的立方和等于该数本身的三位数称为水仙花数,利用C语言编程输出所以水仙花数
#include <stdio.h>
#include <math.h>
int main() {
int i, num, digit, sum;
printf("水仙花数有:\n");
for (i = 100; i < 1000; i++) {
num = i;
sum = 0;
while (num > 0) {
digit = num % 10;
sum += pow(digit, 3);
num /= 10;
}
if (sum == i) {
printf("%d ", i);
}
}
return 0;
}
阅读全文