前言
用C语言实现水仙花数II
一、题目
请判断一个数是不是水仙花数。其中水仙花数定义各个位数立方和等于它本身的三位数
数据包含一个整数n(100<=n<1000)输入0表示程序输入结束
如果n是水仙花数就输出Yes否则输出No
二、使用步骤
1. 思路
- 首先需要知道一个3位数怎样得到各个位置的数(个位、十位、百位)
- 根据水仙花数的定义,各个位数立方和等于它本身的三位数
- 根据题目要求,判断数据n是否为水仙花数,如果是,则输出Yes,否则输出No
- 最后就是控制程序的退出
2. 三位数求各个位数
对于一个三位数n,不妨设为n = 153,则
- 个位:3
n % 10; // 153 % 10 = 3;
- 十位:5
n / 10 % 10; // 153 /10 = 15; 15 % 10 = 5;
- 百位:1
n / 100; // 153 / 100 = 1;
3. 判断是否为水仙花数
代码如下:
i = n % 10; // 计算个位
j = n / 10 % 10; // 计算十位
k = n / 100; // 计算百位
if (i * i * i + j * j * j + k * k * k == n) // 根据水仙花数的定义判断
{
printf("Yes\n");
}
else
{
printf("No\n");
}
三、具体实现
代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
int main()
{
/*
请判断一个数是不是水仙花数。其中水仙花数定义各个位数立方和等于它本身的三位数
数据包含一个整数n(100 <= n < 1000)输入0表示程序输入结束
如果n是水仙花数就输出Yes否则输出No
*/
int i, j, k;
int n;
while (scanf_s("%d", &n) != EOF)
{
if (n == 0)
{
break;
}
assert(n < 1000 && n >= 100);
i = n % 10; // 计算个位
j = n / 10 % 10; // 计算十位
k = n / 100; // 计算百位
if (i * i * i + j * j * j + k * k * k == n)
{
printf("Yes\n");
}
else
{
printf("No\n");
}
}
return 0;
}