C语言判定输入的一个三位数是不是“水仙花”数。所谓“水仙花数”是指一个3位数,其各位数字立方和等于该数本身,例如:153是一个水仙花数,因为153=13+53+33。
时间: 2024-05-03 12:21:18 浏览: 50
#include <stdio.h>
int main() {
int num, sum = 0, temp;
printf("请输入一个三位数:");
scanf("%d", &num);
temp = num;
while(temp != 0) {
int digit = temp % 10;
sum += digit * digit * digit;
temp /= 10;
}
if(sum == num) {
printf("%d是水仙花数\n", num);
} else {
printf("%d不是水仙花数\n", num);
}
return 0;
}
相关问题
用c语言打印水仙花数 n 是一个三位数,所以其取值范围为 100—999。因此可以 用计数控制循环。对于 n 的每个可能的取值,首先分离出其百位数 k,十位数字 l,个位数字m,然后判定 n 与k3+l3+m3 是否相等,若相等即可确定为水仙花数。
在 C 语言中,打印水仙花数(又称 narcissistic number 或 pluperfect digital invariant)的过程通常涉及到遍历给定的三位数范围,并对每个数进行特定条件的检验。以下是步骤的一个简要概述:
#include <stdio.h>
// 判断是否为水仙花数的函数
int is_narcissistic(int num) {
int hundreds = num / 100; // 百位数
int tens = (num % 100) / 10; // 十位数
int ones = num % 10; // 个位数
return hundreds * hundreds * hundreds + tens * tens * tens + ones * ones * ones == num;
}
int main() {
for (int n = 100; n <= 999; ++n) { // 遍历三位数
if (is_narcissistic(n)) {
printf("%d 是水仙花数.\n", n);
}
}
return 0;
}
这个程序会从100到999依次检查每个数,如果某个数满足n = nnn
的形式(即它的每一位数字立方和等于它本身),则输出该数。
c语言编写一个函数,判定一个数是否为水仙花数。如果是返回1,不是返回0.并用主函数调用,打印出所有的水仙花数。
好的,我来为您解答。
水仙花数是指一个n位数( n>=3 ),它的每个位上的数字的n次幂之和等于它本身。比如153就是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
下面是C语言的代码实现:
#include<stdio.h>
#include<math.h>
int isNarcissistic(int n) {
int sum = 0, temp = n, digit = 0;
while (temp > 0) { // 计算n的位数
temp /= 10;
digit++;
}
temp = n;
while (temp > 0) { // 计算每个位上的数字的n次幂之和
sum += pow(temp % 10, digit);
temp /= 10;
}
if (sum == n) // 判断是否为水仙花数
return 1;
else
return 0;
}
int main() {
int i;
for (i = 100; i <= 999; i++) { // 三位数范围内寻找水仙花数
if (isNarcissistic(i))
printf("%d ", i);
}
return 0;
}
在上述代码中,我们首先定义了一个函数isNarcissistic()
,用于判断一个数是否为水仙花数。这个函数的实现过程如下:
- 首先计算这个数的位数,用于后面计算每个位上的数字的n次幂之和。
- 然后用一个while循环计算每个位上的数字的n次幂之和。
- 最后判断这个数的n次幂之和是否等于它本身,如果是则返回1,不是则返回0。
接着在主函数中,我们用一个for循环从100到999的范围内寻找水仙花数,并用isNarcissistic()
函数进行判断。如果找到了水仙花数,则将其打印出来。
希望能够帮到您!
相关推荐















