用C语言判断一个数是否为水仙花数,要求使用for循环结构实现程序功能。
时间: 2023-04-08 17:03:25 浏览: 232
可以回答这个问题。以下是用C语言判断一个数是否为水仙花数的程序代码:
#include <stdio.h>
#include <math.h>
int main()
{
int num, originalNum, remainder, result = 0, n = 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 是水仙花数", num);
else
printf("%d 不是水仙花数", num);
return 0;
}
相关问题
水仙花数c语言程序for循环
水仙花数( narcissistic number),也称为自恋数,是一种特殊的数字,它的各位数字立方之和等于它本身。例如,153是一个水仙花数,因为1^3 + 5^3 + 3^3 = 153。
在C语言中,你可以通过for循环结构找出所有的三位水仙花数。以下是一个简单的示例程序:
```c
#include <stdio.h>
int is_narcissistic(int num) {
int digits[4], sum = 0;
// 将数字分解为三个位
while (num > 0) {
digits[3] = num % 10; // 取个位
sum += digits[3] * digits[3] * digits[3];
num /= 10;
}
return (sum == num); // 如果和等于原数,则为水仙花数
}
int main() {
for (int i = 100; i <= 999; ++i) { // 遍历三位数范围
if (is_narcissistic(i)) {
printf("%d 是一个水仙花数。\n", i);
}
}
return 0;
}
```
C语言只用循环判断是否为水仙花数
在C语言中,判断一个数是否为水仙花数(也称为 narcissistic number 或 pluperfect digital invariant),就是看它的各个位数字的立方和是否等于它本身。这里我们可以使用一个简单的循环结构来实现:
```c
#include <stdio.h>
#include <stdbool.h>
bool isNarcissistic(int num) {
int digits[10]; // 存储每一位数字
int sum = 0;
int originalNum;
// 将num分解为个位、十位、百位...并存入digits数组
while (num > 0) {
digits[num % 10] += sum; // 避免进位影响当前位
sum *= 10;
originalNum = num;
num /= 10;
}
// 计算每位数字的立方和并与原始数比较
for (int i = 0; i <= 9; i++) {
if (digits[i] != (originalNum / (int)pow(10, i))) { // 检查是否满足水仙花条件
return false;
}
}
return true;
}
int main() {
int input;
printf("请输入一个整数:");
scanf("%d", &input);
if (isNarcissistic(input)) {
printf("%d 是水仙花数。\n", input);
} else {
printf("%d 不是水仙花数。\n", input);
}
return 0;
}
```
这段代码首先将输入的数字分解成各位数字,并累加进位,然后计算每个位置的立方和。循环内对比原数的各个位和立方和是否相等,如果不等则返回false,否则返回true。
阅读全文
相关推荐

















