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



