c语言水仙花数问题1
时间: 2024-10-12 18:15:17 浏览: 30
在C语言中,水仙花数(又称 narcissistic number 或 pluperfect digital invariant)是指一个三位数,其各位数字立方之和等于该数本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153。
要解决这个问题,你可以编写一个函数,遍历从100到999的所有整数,检查每个数是否满足水仙花数的条件。下面是一个简单的示例代码:
```c
#include <stdio.h>
int is_narcissistic(int num) {
int digits[3];
int sum = 0;
// 分离出每一位数字
while (num > 0) {
digits[0] = num % 10; // 最低位
sum += digits[0]*digits[0]*digits[0]; // 累加立方和
num /= 10;
}
// 如果剩余的sum等于原始数,就是水仙花数
return sum == num;
}
int main() {
for (int i = 100; i <= 999; i++) {
if (is_narcissistic(i)) {
printf("%d 是一个水仙花数。\n", i);
}
}
return 0;
}
```
相关问题
c语言水仙花数问题1用C加加写
在C语言中,判断一个数字是否为水仙花数(又称 Narcissistic Number 或 Plindrome Number)是指该数的各个位上的数字立方和等于它本身。例如,153是一个水仙花数,因为 1^3 + 5^3 + 3^3 = 153。
下面是一个简单的C程序,用于检查输入的整数是否为水仙花数:
```c
#include <stdio.h>
int is_narcissistic(int num) {
int sum = 0;
int temp = num;
// 分离每一位数字并计算它们的立方和
while (temp > 0) {
int digit = temp % 10;
sum += digit * digit * digit; // 计算立方
temp /= 10;
}
// 如果和等于原数,则是水仙花数,返回1;否则返回0
return (sum == num) ? 1 : 0;
}
int main() {
int number;
printf("请输入一个整数:");
scanf("%d", &number);
if (is_narcissistic(number)) {
printf("%d是水仙花数。\n", number);
} else {
printf("%d不是水仙花数。\n", number);
}
return 0;
}
```
在这个程序中,我们首先定义了一个 `is_narcissistic` 函数,接受一个整数作为参数,然后通过循环处理每一位数字并求其立方和。主函数中获取用户输入,并调用这个函数判断是否为水仙花数。
C语言水仙花数
C语言水仙花数指的是一个n位数,它的每个位上的数字的n次幂之和等于它本身。例如,153是一个3位水仙花数,因为1³ + 5³ + 3³ = 153。下面是一个C语言实现水仙花数的程序:
```c
#include <stdio.h>
#include <math.h>
int main() {
int num, originalNum, remainder, n = 0, result = 0;
printf("请输入一个整数:");
scanf("%d", &num);
originalNum = num;
// 计算位数
while (originalNum != 0) {
originalNum /= 10;
++n;
}
originalNum = num;
// 计算每个位数的n次幂之和
while (originalNum != 0) {
remainder = originalNum % 10;
result += pow(remainder, n);
originalNum /= 10;
}
// 判断是否为水仙花数
if (result == num)
printf("%d 是一个水仙花数\n", num);
else
printf("%d 不是一个水仙花数\n", num);
return 0;
}
```
你可以输入一个整数,程序会判断它是否为水仙花数。
阅读全文